用css画三角形

原理

利用border的特性。

备注

一般情况下,此类三角形都属于小icon类型,所以基本上都是使用::before/::after等伪元素来实现。

实例
例1:
triangle1.png
//css
.triangle1-1{
    width: 0;
    border-left: 80px solid blue;
    border-bottom: 80px solid red;
}
.triangle1-2{
    width: 0;
    border-left: 80px solid blue;
    border-bottom: 80px solid transparent;
}
//html
<div class="triangle1-1"></div>
<div class="triangle1-2"></div>
例2:
triangle2.png
//css
.triangle2-1{
    width: 0;
    border-width: 70px;
    border-style: solid;
    border-top-color: red;
    border-right-color: blue;
    border-bottom-color: green;
    border-left-color: purple;
}
.triangle2-2{
    width: 0;
    border: 70px solid transparent;
    border-top-color: red;
}
.triangle2-expand{
    width: 200px;
    height: 30px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
    position: relative;
}
.triangle2-expand::before,
.triangle2-expand::after{
    content: '';
    border: 10px solid transparent;
    border-bottom-color: #ccc;
    position: absolute;
    top: -20px;
    left: 20px;
}
.triangle2-expand::after{
    border-bottom-color: #fff; /*此处色值要和背景色一致*/
    top: -19px;
}
//html
<div class="triangle2-1"></div>
<div class="triangle2-2"></div>
<div class="triangle2-expand"></div>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • .triangle{ width: 0px; height: 0px; overflow: hidden; bor...
    抛荒了四序阅读 242评论 0 7
  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,781评论 0 8
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,868评论 1 92
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,288评论 19 139
  • 作为一个《悟空传》的铁杆书迷 来来回回的已经看了不下十几遍,也一直期待着能有《悟空传》的电影,第一次听到小道消息...
    __癫痫阅读 574评论 0 1