博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
纯CSS实现对白框
阅读量:6981 次
发布时间:2019-06-27

本文共 1017 字,大约阅读时间需要 3 分钟。

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


通过把border上左设置为有颜色,下右设置为透明,在#demo:before放置一个向下的等边三角形,绝对定位使之顶部与大盒子的下边框重合。

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

html代码:

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不可能是整数),这里需要一些计算。

    图片描述

转载地址:http://irjpl.baihongyu.com/

你可能感兴趣的文章
图解.NET Stack和Heap的本质区别
查看>>
Matlab中struct的用法
查看>>
Mysql LIMIT如何正确对其进行优化
查看>>
Spring10种常见异常解决方法
查看>>
微信 oauth4
查看>>
Android 事件分发机制
查看>>
bzoj1670【Usaco2006 Oct】Building the Moat 护城河的挖掘
查看>>
Java内部类
查看>>
给iPhone手机安装*.ipa
查看>>
近期小结
查看>>
glog 使用
查看>>
Java中hashCode的作用
查看>>
C#中的线程(三) 使用多线程
查看>>
Docker三十分钟快速入门(上)
查看>>
TLS协议分析
查看>>
Android开发-各种各样好看漂亮的进度条,指示器,加载提示汇总
查看>>
ajax传JSON时设置的contenttype导致JAVA中request.getParameter("")怎么也接收不到数据
查看>>
visual studio 中将选中代码相同的代码的颜色设置,修改高亮颜色
查看>>
Tomcat 配置详解/优化方案(转)
查看>>
2018年目标计划
查看>>