三角形css_如何用css绘制三角形?

首先,我们知道用边框实现一个三角形很简单,直接上代码上图。

.triangleTest {        .content div {            width: 0;            height: 0;            &.up {                border-left: 50px solid transparent;                border-right: 50px solid transparent;                border-bottom: 100px solid red;                border-top: 0;            }        }    }
f5ac809394b1b87ce27940b4a7f30adc.png

可以看到用样式的border-width来实现一个三角形很简单,但是本文会从原理上来讲解,为什么会这样展示。

#box{            width:200px;            height:200px;            background:yellow;            border-top: 80px solid red;            border-right:80px solid black;            border-bottom:80px solid green;            border-left:80px solid blue;        }
d0855279a5576ffd614c9e8599a8a70f.png

可以看到,盒子宽高都为200px,边框都是80px,由于边框颜色不同,可以很明显的看出是以梯形的方式向内容区域(黄色区域),覆盖。如果长或者宽小于最大边框时,则内容区域不可见(黄色区域),就是说当盒子长宽小于160px(80 + 80)那么表现出来就是4个三角形。

32b69cd92e0ca9909067a05745f93aa8.png


我们再回到第一个例子,就很好解释为啥是个三角形了,因为左边和右边边框都是透明色,看不到,所以就只能看到底边框形成的一个向上的三角形。
根据上面的原理,我们能实现很多种三角形,梯形。

.left {                border-left: 50px solid red;                border-top: 50px solid red;                border-right: 50px solid transparent;                border-bottom: 50px solid transparent;            }
032b1612520099d140fd80fc6215c646.png
.right {                border-left: 50px solid transparent;                border-top: 50px solid transparent;                border-right: 50px solid red;                border-bottom: 50px solid red;            }
f73fc468370c52e1fa7cda6de0f8349a.png
.bottom-left {                width: 120px;                height: 120px;                background-color: transparent;                border-left: 50px solid transparent;                border-top: 50px solid transparent;                border-right: 50px solid transparent;                border-bottom: 50px solid red;            }
13f17a99046bce2fc6d0e97c0aadb1cb.png

可以看到,理解了边框实现三角形的原理,就能绘制各式各样的图形了。


线上体验地址:https://jackzhujie.github.io/vue-study/#/triangleTest
所有的源码都可以在我的仓库地址:https://github.com/jackzhujie/vue-study
个人博客:http://blog.aizhifou.cn

学习如逆水行舟,不进则退,前端技术飞速发展,如果每天不坚持学习,就会跟不上,我会陪着大家,每天坚持推送博文,跟大家一同进步,希望大家能关注我,第一时间收到最新文章。


版权声明:本文为weixin_39878855原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。