纯ccs 伪元素 实现内圆弧

<html lang="en">

 

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<meta http-equiv="X-UA-Compatible" content="ie=edge">

<title>Document</title>

<style>

.one,

.two,

.three {

width: 200px;

height: 100px;

text-align: center;

border: 2px solid black;

display: inline-block;

position: relative;

justify-content: center;

margin: 0 auto;

box-sizing: border-box !important;

}

 

.one::after,

.one::before,

.two::before,

.two::after,

.three::before,

.three::after {

content: '';

pointer-events: none;

position: absolute;

display: block;

width: 20px;

height: 20px;

border-radius: 20px;

background-color: white;

}

 

.one::before,

.two::before,

.three::before {

top: 35px;

left: -9px;

}

 

.one::after,

.two::after,

.three::after {

top: 35px;

right: -9px;

}

 

.one::before {

background-color: white;

border-color: transparent;

border-right: 2px solid black;

border-bottom: 2px solid black;

transform: rotate(-45deg);

border-radius: 20px;

}

 

.one::after {

border-color: transparent;

border-left: 2px solid black;

border-bottom: 2px solid black;

border-radius: 20px;

transform: rotate(45deg);

}

 

.two {

background-color: black;

color: white;

}

 

.three::before {

border-radius: 0 125% 125% 0 / 0 100% 100% 0;

border: 1px solid black;

border-left: transparent;

background: white;

left: -3px;

}

 

.three::after {

border-radius: 125% 0 0 125% / 100% 0 0 100%;

/* border-radius: 0 200% 200% 0 / 0 100% 100% 0; */

border: 1px solid black;

border-right: transparent;

background: white;

right: -3px;

}

</style>

</head>

 

<body style="text-align: center;flex-direction:row; ">

<div class="one">两个伪元素实现</div>

<div class="two">两个伪元素实现</div>

<div class="three">单个伪元素实现</div>

</body>

 

</html>

</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值