如何用css画正三角形?
首先,我们知道用边框实现一个三角形很简单,直接上代码上图。
<div class="content">
<div class="up"></div>
</div>
.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;
}
}
}
data:image/s3,"s3://crabby-images/17f54/17f54f4c1c3a69043f166ffecc9388db050ebc10" alt=""
可以看到用样式的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;
}
data:image/s3,"s3://crabby-images/c522f/c522fdf6f30e06ed14040bb1dd94c947478aae43" alt=""
可以看到,盒子宽高都为200px,边框都是80px,由于边框颜色不同,可以很明显的看出是以梯形的方式向内容区域(黄色区域),覆盖。如果长或者宽小于最大边框时,则内容区域不可见(黄色区域),就是说当盒子长宽小于160px(80 + 80)那么表现出来就是4个三角形。
data:image/s3,"s3://crabby-images/5d698/5d69862460bc2cb4ebbb54fbde90d7325b86f36c" alt=""
我们再回到第一个例子,就很好解释为啥是个三角形了,因为左边和右边边框都是透明色,看不到,所以就只能看到底边框形成的一个向上的三角形。
根据上面的原理,我们能实现很多种三角形,梯形。
.left {
border-left: 50px solid red;
border-top: 50px solid red;
border-right: 50px solid transparent;
border-bottom: 50px solid transparent;
}
data:image/s3,"s3://crabby-images/6acec/6acecd12eda8748317e3624c8daea3d646670f86" alt=""
.right {
border-left: 50px solid transparent;
border-top: 50px solid transparent;
border-right: 50px solid red;
border-bottom: 50px solid red;
}
data:image/s3,"s3://crabby-images/504a5/504a576ac26a2cbd3bce466bb395fc93adc991f7" alt=""
.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;
}
data:image/s3,"s3://crabby-images/629fb/629fbb49af7c0545416549bc7c3a3bfc6aca6e81" alt=""
可以看到,理解了边框实现三角形的原理,就能绘制各式各样的图形了。