乐趣区

CSS3径向渐变radial-gradient实现波浪边框和内倒角

前言
大佬给了一张优惠券图片(如下图),我一看,这波浪型的边框和内倒角用 css 写不出来吧,遂向大佬说明并要 ui 切图,大佬回答:css3 可以实现。好吧,大佬都说可以实现了,还不赶紧去求谷哥,度娘。

实现内倒角
上代码,然后解释代码
<div class=”radial-gradient”></div>
<style>
.radial-gradient {
width: 200px;
height: 100px;
position: relative;
background-image: radial-gradient(circle at right top, #fff, #fff 10px, transparent 11px),
radial-gradient(circle at right bottom, #fff, #fff 10px, transparent 11px);
background-color: red;
}
</style>
.radial-gradient 的样式不用解释,懂点 css 都知道。关键在于.radial-gradient:after 样式。
重点解释 radial-gradient(circle at right top, #fff, #fff 10px, transparent 11px)这个样式是干嘛的。
circle 表示圆形渐变,说的简单点就是画一个圆。画圆就要知道原点。
circle at right top 中的 right top 就是原点位置。这里原点位置是相对于容器的坐标。right 表示容器最右边,top 表示容器最上边,换言之就是右上角。
circle at right top 后面的 #fff, #fff 10px, transparent 11px 就是从原点开始各种颜色渐变的长度。
代码 #fff, #fff 10px, transparent 11px 中第一个 #fff 表示原点处为#fff 颜色,#fff 10px 表示距离原点半径 10px 这段距离都是 #fff 颜色,transparent 11px 表示距离原点 10px 到 11px 都是 transparent 颜色,由于没有设置其他颜色,所以距离原点 11px 以后都是 transparent 颜色。

总结 radial-gradient(circle at right top, #fff, #fff 10px, transparent 11px), 就是以容器的右上角为原点画圆,半径 10px 范围内是 #fff 颜色,半径大于 10px 范围内都是 transparent 颜色。
这样在右上角就形成了内倒角
同理 radial-gradient(circle at right bottom, #fff, #fff 10px, transparent 11px); 就不解释了。
实现波浪边框
上代码,增加一个 css 样式即可
<style>
.radial-gradient:after {
content: ”;
position: absolute;
top: 0px;
bottom: 0px;
left: -5px;
width: 10px;
height: 100%;
background: radial-gradient(circle, #fff, #fff 4px, transparent 5px);
background-size: 10px 10px;
}
</style>
background: radial-gradient(circle, #fff, #fff 4px, transparent 5px); 此处没有 at right top 字样,表示原点在容器中心位置,#fff, #fff 4px, transparent 5px,表示半径 4px 范围内是 #fff 颜色,半径大于 4px 范围内都是 transparent 颜色。这样就有一个直径为 8px 的#fff 颜色的圆位于容器 (这里的容器是:after) 中心。
(背景蓝色是为了演示效果)
再加上 background-size: 10px 10px; 设置背景大小为宽 10px 高 10px,这样就能实现多个直径为 8px 的 #fff 颜色的圆。
(背景蓝色是为了演示效果)
left: -5px; 向左偏移 5px,使:after 只有一半在.radial-gradient 容器内
最后附上效果图

总结
实现内倒角其实是画一个 #fff 颜色的圆,圆只有四分之一在容器内
实现波浪边框其实是画多个 #fff 颜色的圆,圆只有一半在容器内
参考文献:10 个 demo 示例学会 CSS3 radial-gradient 径向渐变 CSS- 论 css 如何纯代码实现内凹圆角

退出移动版