纯CSS实现对白框
程序员文章站
2022-04-26 11:24:55
...
如果一个盒子的长宽都为零,那么它的四条border就会碰到一起,变成实心的,而且每一条border都是一个三角形;我们就可以利用三角形来实现对白框的尖下巴。
通过把border上左设置为有颜色,下右设置为透明,在#demo:before
放置一个向下的等边三角形,绝对定位使之顶部与大盒子的下边框重合。
再通过把border上左设置为白色,下右设置为透明,在大三角形里面放置一个白色小三角形,覆盖掉一部分颜色,就形成了尖下巴。
可以用#demo:before
和#demo:after
伪元素来实现,也可以在大盒子里放置小盒子再绝对定位。
html代码:
<p id="demo"></p>
css代码:
#demo { width: 200px; height: 100px; background:#FFF; border: 8px solid #666; border-radius: 30px; box-shadow: 2px 2px 4px #888; position: relative; } #demo:before { content:""; position: absolute; left: 30px; top: 100px; border: 25px solid; border-color: #666 transparent transparent #666; } #demo:after { content:""; position: absolute; left: 38px; top: 100px; border: 15px solid; border-color: #FFF transparent transparent #FFF; }
有几个细节需要注意:
#demo:after
的两条有色边框应该与盒子的背景颜色相同,所以要记得给盒子设置背景颜色,而不是透明;此处我将盒子背景设置为与边框相同的白色。此处有绝对定位,可以不给border设置
width:0px;height:0px;
,正常情况是需要的,否则边框就会拉伸成一行。如下图,黑三角形的两条边框减去白三角形的两条边框等于(c+d),而为了美观,d应该约等于a(c必须是整数,所以a不可能是整数),这里需要一些计算。
更多纯CSS实现对白框相关文章请关注PHP中文网!
下一篇: css链接式和导入式的区别
推荐阅读
-
利用纯css3实现的文字亮光特效的代码演示
-
纯CSS实现表单验证_html/css_WEB-ITnose
-
一款纯css3实现的机器人看书动画效果_html/css_WEB-ITnose
-
一款利用纯css3实现的win8加载动画的实例分析
-
纯CSS3实现鼠标悬停提示气泡效果
-
使用css3和jquery实现可伸缩搜索框
-
css3+贝塞尔曲线实现可伸缩input搜索框效果
-
请问如何实现table的外框和内框线的粗度不同??_html/css_WEB-ITnose
-
使用checkbox实现纯CSS下拉框_html/css_WEB-ITnose
-
纯CSS3实现彩色缎带效果_html/css_WEB-ITnose