您好,欢迎来到爱玩科技网。
搜索
您的当前位置:首页纯CSS实现对白框

纯CSS实现对白框

来源:爱玩科技网
 如果一个盒子的长宽都为零,那么它的四条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;
}

有几个细节需要注意:

  1. #demo:after的两条有色边框应该与盒子的背景颜色相同,所以要记得给盒子设置背景颜色,而不是透明;此处我将盒子背景设置为与边框相同的白色。

  2. 此处有绝对定位,可以不给border设置width:0px;height:0px;,正常情况是需要的,否则边框就会拉伸成一行。

  3. 如下图,黑三角形的两条边框减去白三角形的两条边框等于(c+d),而为了美观,d应该约等于a(c必须是整数,所以a不可能是整数),这里需要一些计算。


更多纯CSS实现对白框相关文章请关注PHP中文网!

Copyright © 2019- aiwanbo.com 版权所有 赣ICP备2024042808号-3

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务