三角形实现原理:宽度width为0;height为0;(1)有一条横竖边(上下左右)的设置为border-方向:长度 solid red,这个画的就是底部的直线。其他边使用border-方向:长度 solid transparent。(2)有两个横竖边(上下左右)的设置,若斜边是在三角形的右边,这时候设置top或bottom的直线,和右边的斜线。若斜边是在三角形的左边,这时候设置top或bottom的直线,和左边的斜线。
二、实现
2.1 Triangle Up
data:image/s3,"s3://crabby-images/a9ab3/a9ab30ba91c83369a414ef17c6647aca29abb1bd" alt=""
#triangle-up {
width:
0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-bottom: 100px solid red;
}
2.2 Triangle Down
data:image/s3,"s3://crabby-images/15cc2/15cc284734c42b64ec3070b6499e1bdf86e67e63" alt=""
#triangle-down {
width:
0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-top: 100px solid red;
}
2.3 Triangle Left
data:image/s3,"s3://crabby-images/f3579/f3579b664219aea23769e7b5c86ecec834eea1bd" alt=""
#triangle-left {
width:
0;
height: 0;
border-top: 50px solid transparent;
border-right: 100px solid red;
border-bottom: 50px solid transparent;
}
2.4 Triangle Right
data:image/s3,"s3://crabby-images/21efe/21efe0bc205e5c18fece57ab8101f8ba77df84d5" alt=""
#triangle-right {
width:
0;
height: 0;
border-top: 50px solid transparent;
border-left: 100px solid red;
border-bottom: 50px solid transparent;
}
2.5 Triangle Top Left
data:image/s3,"s3://crabby-images/081bd/081bdff13ae05244acfcea677689690f17c15f4a" alt=""
#triangle-topleft {
width:
0;
height: 0;
border-top: 100px solid red;
border-right: 100px solid transparent;
}
2.6 Triangle Top Right
data:image/s3,"s3://crabby-images/ce925/ce9256eff626658b6aa6dffd45f0a1cbafd95e08" alt=""
#triangle-topright {
width:
0;
height: 0;
border-top: 100px solid red;
border-left: 100px solid transparent;
}
2.7 Triangle Bottom Left
data:image/s3,"s3://crabby-images/6e279/6e279528e38b15936c895bc9e8c349d051cf52dd" alt=""
#triangle-bottomleft {
width:
0;
height: 0;
border-bottom: 100px solid red;
border-right: 100px solid transparent;
}
2.8 Triangle Bottom Right
data:image/s3,"s3://crabby-images/d274b/d274b7a58d4354328a688156005ef0e69c92cab5" alt=""
#triangle-bottomright {
width:
0;
height: 0;
border-bottom: 100px solid red;
border-left: 100px solid transparent;
}