borderRadius百分比50和100究竟有什么区别

border-radius的值是百分比的话,就相当于盒子的宽度和高度的百分比。我们知道在一个正方形内做一个面积最大的圆形,这个圆的半径就为正方形边长的一半。所

以border-radius为50%时,则会形成圆。那么可能有人就会问,border-radius为100%时,对应圆的半径长度不就是正方形的宽高么,这种情况下,为什么还是会

形成一个和值为50%一样的圆形呢?


  其实这是W3C对于重合曲线有这样的规范:如果两个相邻角的半径和超过了对应的

盒子的边的长度,那么浏览器要重新计算保证它们不会重合。下面我们假定一个宽

高为100px的正方形A。此时设置border-top-left-radius=100%;则正方形A会变成一个半径为100px的四分之一圆弧。

radius1

  然后我们再给border-top-right-radius=100%。此时相邻的角的半径已经超过了对应的盒子的边的长度。浏览器需要重新计算。重新计算的规则是同时缩放两

个圆角的半径知道他们刚好符合这个方形。

  建议使用border-radius = 50% 来避免浏览器不必要的计算。值得注意的是在涉及到与圆角相关动画的情况下,值为50%和100%,在动画效果上会有不同。

示例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>动画效果差异</title>
</head>
<style>
div{
width: 100px;
height: 100px;
margin-bottom: 10px;

transition: border-radius 3s;

}
.half{
border-radius: 50%;
background: #000;
}
.full{
border-radius: 100%;
background: #f00;
}

.box1:hover div{
border-radius: 0;
}
.wrap{
width:100px;
height: 250px;
border: 1px solid red;
cursor: pointer;
}

.box2 .half{
border-radius: 0;
background: #000;
}

.box2 .full{
border-radius: 0;
background: #f00;
}
.box2:hover .half{
border-radius: 50%;
}
.box2:hover .full{
border-radius:100%
}
</style>
<body>
<div class='wrap box1'>
<div class="half"></div>
<div class="full"></div>
</div>

<div class='wrap box2'>
<div class="half"></div>
<div class="full"></div>
</div>
<p>将鼠标移到红框内</p>
</body>
</html>
本文结束感谢您的阅读

本文标题:borderRadius百分比50和100究竟有什么区别

文章作者:陈宇(cosyer)

发布时间:2019年04月01日 - 00:04

最后更新:2019年04月01日 - 01:04

原始链接:http://mydearest.cn/2019/borderRadius%E7%99%BE%E5%88%86%E6%AF%9450%E5%92%8C100%E7%A9%B6%E7%AB%9F%E6%9C%89%E4%BB%80%E4%B9%88%E5%8C%BA%E5%88%AB.html

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

坚持原创技术分享,您的支持将鼓励我继续创作!