视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
css实现凸字形状的代码实例
2020-11-27 18:47:33 责编:小采
文档
 本篇文章给大家带来的内容是关于css实现凸字形状的代码实例,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

昨天看到有人想做凸字型框,今天用几分钟做了一下,发现还蛮巧妙的,分享一下

最终效果如下所示


代码在这儿:

 <div class="box">
 <span class="big"></span>
 <span class="top"></span>
 <span class="topR"></span>
 </div>
body {
 display: flex;
 justify-content: center;
 align-items: center;
 
 
 .box {
 position: relative;
 width: 400px;
 height: 400px;
 top: 200px;
 color: lightblue;
 
 
 .big {
 position: absolute;
 width: 400px;
 height: 200px;
 border-radius: 20px;
 background-color: currentColor;
 bottom: 0;
 }
 
 .top {
 position: absolute;
 width: 100px;
 left: calc((400px - 100px)/2);
 height: 150px;
 border-radius: 20px 20px 0 0;
 background-color: currentColor;
 top: 50px;
 }
 
 .top::before {
 content: "";
 position: absolute;
 background-color: lightblue;
 height: 48px;
 width: 100px;
 left: -100px;
 top: 102px;
 }
 
 .top::before {
 content: "";
 position: absolute;
 background-color: lightblue;
 height: 48px;
 width: 100px;
 left: -100px;
 top: 102px;
 }
 
 .top::after {
 content: "";
 position: absolute;
 background-color: #fff;
 border-radius: 0 0 20px 0;
 height: 48px;
 width: 100px;
 left: -100px;
 top: 102px;
 }
 
 .topR {
 position: absolute;
 background-color: lightblue;
 height: 48px;
 width: 100px;
 right: 50px;
 top: 152px;
 }
 
 .topR::after {
 content: "";
 position: absolute;
 background-color: #fff;
 border-radius: 0 0 0 20px;
 height: 48px;
 width: 100px;
 left: 0;
 top: 0;
 }
 }
}

一开始我以为只要上下两个圆角矩形拼接就行,NO NO NO,其实两个圆角相交处还有圆角,一看这个圆角就知道,可以使用白色的圆角矩形覆盖,那么问题来了:
白色的圆角矩形覆盖之后,中间会形成空隙,这个空隙需要蓝色填满。所以思路是这样的:

一、先建立上下两个圆角矩形:
HTML:

 <span class="big"></span>
 <span class="top"></span>

二:在上面的圆角矩形左右各加一个蓝色色的圆角矩形,与上下两个矩形相切,但是长度和宽度都不能超过上下两个大矩形

三:再在后来添加的小蓝色矩形块儿上,各增加一个大小一致的白色矩形覆盖,分别设置右下圆角与左下圆角,代码如下:

border-radius: 0 0 20px 0;
border-radius: 0 0 0 20px;

OK,大功告成!一个凸型框就制作好啦。

下载本文
显示全文
专题