我们知道在边框的四个角实现圆角可以用 border-radius 实现, 如果在边框中心实现边框的内凹效果呢?
效果如下图:
要实现上图的效果可以分为五个步骤:
- 用一个
div作为大容器, 设置1px的边框及圆角 - 利用伪元素
::before, ::after创建两个边框1px且边框颜色同大容器的圆, 圆的背景色同该模块的背景色(障眼法) - 子绝父相, 将两个圆分别定位在左右两边
- 将伪元素的其中两条边设置为透明(同三角形的做法)
- 通过
transform: rotate()设置合适的旋转角度
源代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>圆角边框的实现方法</title>
<style>
div {
position: relative;
width: 300px;
height: 150px;
border: 1px solid #f60;
margin: 100px auto;
border-radius: 5px;
}
// 添加伪元素
div::before,
div::after {
position: absolute;
top: 50%;
margin-top: -5px;
content: '';
width: 9px;
height: 9px;
background-color: #fff;
border: 1px solid #f60;
border-left-color: transparent;
border-bottom-color: transparent;
border-radius: 50%;
}
div::before {
left: -6px;
transform: rotate(45deg);
}
div::after {
right: -6px;
transform: rotate(-135deg);
}
</style>
</head>
<body>
<div></div>
</body>
</html>
版权声明:本文为liliy__原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。