1

<div>我正在尝试围绕这样的凹形顶部和底部边框:

我想做的事的例子

我当前的 CSS:

.div:after {    
    content:'';
    position:absolute;
    left:-600%;
    width:1300%;
    padding-bottom:1300%;
    top:80%;
    background:none;
    border-radius:50%;
    box-shadow: 0px 0px 0px 20px #f2f2f2;
    z-index:-1;
}

但它只适用于底部边框,有时会在移动设备上消失。

这是JS 小提琴

4

1 回答 1

3

您可以使用:before:after伪元素来绘制此形状。

.div {
  position: relative;
  overflow: hidden;
  padding: 50px 0;
}

.div-inner {
  position: relative;
  background: black;
  height: 120px;
}

.div-inner:before,
.div-inner:after {
  box-shadow: 0 0 0 80px #000;
  border-radius: 100%;
  position: absolute;
  height: 150px;  /* You can change height to increase or decrease concave radius */ 
  content: '';
  right: -20%;
  left: -20%;
  top: 100%;
}

.div-inner:after {
  bottom: 100%;
  top: auto;
}
<div class="div">
  <div class="div-inner"></div>
</div>

于 2016-11-22T10:31:29.710 回答