实现方法:1、利用高宽为零的容器和透明的border;2、利用线性渐变linear-gradient;3、使用“transform:rotate”配合“overflow:hidden”;4、利用“▼”、“▲”等字符绘制。

本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。
使用 border 绘制三角形
使用 border 实现三角形应该是大部分人都掌握的,也是各种面经中经常出现的,利用了高宽为零的容器及透明的 border 实现。
简单的代码如下:
html, body { width: 100%; height: 100%; display: flex;}div { width: 0px; height: 0px; margin: auto;}.normal { border-top: 50px solid yellowgreen; border-bottom: 50px solid deeppink; border-left: 50px solid bisque; border-right: 50px solid chocolate;}
高宽为零的容器,设置不同颜色的 border:
立即学习“前端免费学习笔记(深入)”;

这样,让任何三边的边框的颜色为 transparent,则非常容易得到各种角度的三角形:
.top { border: 50px solid transparent; border-bottom: 50px solid deeppink;}.left { border: 50px solid transparent; border-right: 50px solid deeppink;}.bottom { border: 50px solid transparent; border-top: 50px solid deeppink;}.right { border: 50px solid transparent; border-bottom: 50px solid deeppink;}

使用 linear-gradient 绘制三角形
接着,我们使用线性渐变 linear-gradient 实现三角形。
它的原理也非常简单,我们实现一个 45° 的渐变:
div { width: 100px; height: 100px; background: linear-gradient(45deg, deeppink, yellowgreen);}

让它的颜色从渐变色变为两种固定的颜色:
div { width: 100px; height: 100px; background: linear-gradient(45deg, deeppink, deeppink 50%, yellowgreen 50%, yellowgreen 100%);}

再让其中一个颜色透明即可:
div { background: linear-gradient(45deg, deeppink, deeppink 50%, transparent 50%, transparent 100%);}

transform: rotate 配合 overflow: hidden 绘制三角形
这种方法还是比较常规的,使用 transform: rotate 配合 overflow: hidden。一看就懂,一学就会,简单的动画示意图如下:

设置图形的旋转中心在左下角 left bottom,进行旋转,配合 overflow: hidden。
完整的代码:
html, body { width: 100%; height: 100%; display: flex;}div { width: 141px; height: 100px; margin: auto;}.demo-opacity { overflow: hidden;}.demo,.demo-opacity { position: relative; border: 1px solid #000; background: unset; &::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; animation: conicmove 3s infinite linear; background: deeppink; transform-origin: left bottom; z-index: -1; }}.triangle { position: relative; background: unset; overflow: hidden; &::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: deeppink; transform-origin: left bottom; transform: rotate(45deg); z-index: -1; }}@keyframes conicmove { 100% { transform: rotate(45deg); }}
利用字符绘制三角形
OK,最后一种,有些独特,就是使用字符表示三角形。
下面列出一些三角形形状的字符的十进制 Unicode 表示码。
◄ : ◄ ► : ► ▼ : ▼ ▲ : ▲⊿ : ⊿△ : △
譬如,我们使用 ▼ 实现一个三角形 ▼,代码如下:
▼
div { font-size: 100px; color: deeppink;}
效果还是不错的:

(学习视频分享:css视频教程)
以上就是css怎么实现三角形的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1621831.html
微信扫一扫
支付宝扫一扫