用CSS绘制箭头等三角形图案 [译]
最近重新设计了我的网站,准备添加tooltips提示信息效果.实现很容易,但我想要让提示功能具有三角形的指示图标。
当我重新思考想要所设计的每个图标颜色都随心所欲的时候,采用图片那就是一场灾难。
幸运的是, MooTools 的核心开发者 Darren Waddell介绍了一个强大的技巧给我:CSS三角形.只使用纯CSS语言,你就能创建兼容各个浏览器的三角形,用很少的代码。
不使用伪类的 CSS 代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | /* 向上的箭头,类似于A,只有三个边,不能指定上边框 */ div.arrow-up { width : 0 ; height : 0 ; border-left : 5px solid transparent ; /* 左边框的宽 */ border-right : 5px solid transparent ; /* 右边框的宽 */ border-bottom : 5px solid #2f2f2f ; /* 下边框的长度|高,以及背景色 */ font-size : 0 ; line-height : 0 ; } /* 向下的箭头 类似于 V */ div.arrow-down { width : 0 ; height : 0 ; border-left : 20px solid transparent ; border-right : 20px solid transparent ; border-top : 20px solid #f00 ; font-size : 0 ; line-height : 0 ; } /* 向左的箭头: 只有三个边:上、下、右。而 <| 总体来看,向左三角形的高=上+下边框的长度。 宽=右边框的长度 */ div.arrow- left { width : 0 ; height : 0 ; border-bottom : 15px solid transparent ; /* 下边框的高 */ border-top : 15px solid transparent ; /* 上方边框的高 */ border-right : 10px solid yellow; /* 右边框的长度|宽度,以及背景色 */ font-size : 0 ; line-height : 0 ; } /* 向右的箭头: 只有三个边:上、下、左。而 |> 总体来看,向右三角形的高=上+下边框的长度。 宽=左边框的长度 */ div.arrow- right { width : 0 ; height : 0 ; border-bottom : 15px solid transparent ; /* 下边框的高 */ border-top : 15px solid transparent ; /* 上方边框的高 */ border-left : 60px solid green ; /* 左边框的长度|宽度,以及背景色 */ font-size : 0 ; line-height : 0 ; } |
其中的秘密,就是这些三角形在你要指向的方向垂直的两边, 有巨大的边框,而让背面的边框设置为你喜欢的颜色即可。
边框越大,三角形就越大。调整三个边框的长度,就可以构建出各种不同的三角形。如果加上旋转,不知道似的否可以指定各种不同方向的图形?
当然,这个处理方法优越的地方就在于代码量非常少,同时非常灵活。
带有 :before 和 :after 的CSS三角形
前面的例子可以很好的工作,但是如果你想要不只是一个三角形怎么办?比如气泡对话框,那么可以使用伪类来实现CSS三角形箭头,对于弹出的提示信息来说非常完美,代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | div.tooltip { /* tooltip content styling in here; nothing to do with arrows */ } /* shared with before and after */ div.tooltip:before, div.tooltip:after { content : ' ' ; height : 0 ; position : absolute ; width : 0 ; border : 10px solid transparent ; /* arrow size */ } /* 向上的箭头 */ /* top-stacked, smaller arrow */ div.tooltip:before { border-bottom-color : #fff ; /* arrow color */ /* positioning */ position : absolute ; top : -19px ; left : 255px ; z-index : 2 ; } /* arrow which acts as a background shadow */ div.tooltip:after { border-bottom-color : #333 ; /* arrow color */ /* positioning */ position : absolute ; top : -24px ; left : 255px ; z-index : 1 ; } |
一般来说在箭头的背面边框指定颜色,也可以只使用 :before 或者 :after 之中的一个。而第二个箭头,可以被当作背景边框,或者作为第一个的阴影。
我想问自己为什么不早点知道这种技术。这个优雅的技巧肯定会让我在将来大大的提高制作tooltip元素的水平,同时也为我打开了一个广阔的视野。
完整的页面示例代码如下:
<! DOCTYPE html> < html xmlns="http://www.w3.org/1999/xhtml" dir="ltr"> < head > < title >CSS 箭头Demo</ title > < style type="text/css"> /* 向上的箭头,类似于A,只有三个边,不能指定上边框 */ div.arrow-up { width: 0; height: 0; border-left: 5px solid transparent; /* 左边框的宽 */ border-right: 5px solid transparent; /* 右边框的宽 */ border-bottom: 5px solid #2f2f2f; /* 下边框的长度|高,以及背景色 */ font-size: 0; line-height: 0; } /* 向下的箭头 类似于 V */ div.arrow-down { width: 0; height: 0; border-left: 20px solid transparent; border-right: 20px solid transparent; border-top: 20px solid #f00; font-size: 0; line-height: 0; } /* 向左的箭头: 只有三个边:上、下、右。而 <| 总体来看,向左三角形的高=上+下边框的长度。 宽=右边框的长度 */ div.arrow-left { width: 0; height: 0; border-bottom: 15px solid transparent; /* 下边框的高 */ border-top: 15px solid transparent; /* 上方边框的高 */ border-right: 10px solid yellow; /* 右边框的长度|宽度,以及背景色 */ font-size: 0; line-height: 0; } /* 向右的箭头: 只有三个边:上、下、左。而 |> 总体来看,向右三角形的高=上+下边框的长度。 宽=左边框的长度 */ div.arrow-right { width: 0; height: 0; border-bottom: 15px solid transparent; /* 下边框的高 */ border-top: 15px solid transparent; /* 上方边框的高 */ border-left: 60px solid green; /* 左边框的长度|宽度,以及背景色 */ font-size: 0; line-height: 0; } /* 基本样式 */ .tip { background: #eee; border: 1px solid #ccc; padding: 10px; border-radius: 8px; box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); position: relative; width: 200px; } /* 箭头 - :before and :after, 一起组成了好看的气泡小箭头 */ .tip:before { position: absolute; display: inline-block; border-top: 7px solid transparent; border-right: 7px solid #eee; border-bottom: 7px solid transparent; border-right-color: rgba(0, 0, 0, 0.2); left: -8px; top: 20px; content: ''; } /* 背景阴影*/ .tip:after { position: absolute; display: inline-block; border-top: 6px solid transparent; border-right: 6px solid #eee; border-bottom: 6px solid transparent; left: -6px; top: 21px; content: ''; } </ style > </ head > < body > < div id="contentHolder"> < h1 >CSS 箭头Demo</ h1 > < p >以下代码.是极好的纯 CSS 箭头样式,不使用背景图!</ p > < div id="position:relative;"> < div class="arrow-up">向上的箭头</ div > < br /> < div class="arrow-down">向下的箭头</ div > < br /> < div class="arrow-left">向左的箭头</ div > < br /> < div class="arrow-right">向右的箭头</ div > </ div > < h2 >CSS 箭头气泡 ,使用 伪类(Pseudo-Element)</ h2 > < div style="position:relative;"> < div class="tip"> 企业级开发首选技术是什么?JavaEE和.Net哪个技术更好?在JavaEE开发中主要用哪些框架?另外在移动大热的趋势下如何开发出一个成功的Android产品? </ div > < br /> < div class="tip"> 向左的箭头: 只有三个边:上、下、右。而 < | 总体来看,向左三角形的高=上+下边框的长度。 宽=右边框的长度< br /> 向右的箭头: 只有三个边:上、下、左。而 |> 总体来看,向右三角形的高=上+下边框的长度。 宽=左边框的长度< br /> 向上的箭头,类似于A,只有三个边,不能指定上边框 </ div > </ div > </ div > </ body > </ html > |
原文地址:http://davidwalsh.name/css-triangles
演示地址:http://davidwalsh.name/demo/css-triangles.php
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!