纯css实现对白框

如果一个盒子的长宽都为零,那么它的四条border就会碰到一起,变成实心的,而且每一条border都是一个三角形;我们就可以利用三角形来实现对白框的尖下巴。


通过把border上左设置为有颜色,下右设置为透明,在#demo:before放置一个向下的等边三角形,绝对定位使之顶部与大盒子的下边框重合。
再通过把border上左设置为白色,下右设置为透明,在大三角形里面放置一个白色小三角形,覆盖掉一部分颜色,就形成了尖下巴。
可以用#demo:before和#demo:after伪元素来实现,也可以在大盒子里放置小盒子再绝对定位。

html代码

  1. <div id="demo"></div>
复制代码

css代码

  1. #demo {
  2. width: 200px;
  3. height: 100px;
  4. background:#FFF;
  5. border: 8px solid #666;
  6. border-radius: 30px;
  7. box-shadow: 2px 2px 4px #888;
  8. position: relative;
  9. }
  10. #demo:before {
  11. content:"";
  12. position: absolute;
  13. left: 30px;
  14. top: 100px;
  15. border: 25px solid;
  16. border-color: #666 transparent transparent #666;
  17. }
  18. #demo:after {
  19. content:"";
  20. position: absolute;
  21. left: 38px;
  22. top: 100px;
  23. border: 15px solid;
  24. border-color: #FFF transparent transparent #FFF;
  25. }
复制代码

有几个细节需要注意:

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值