border-radius:50%和100%究竟有什么区别
2016-08-28 15:54
239 查看
之前写css圆形时总是直接设置border-radius为50%。后来看某css动画网站时发现作者都是用的100%。遂去了解了一下2者的差别。
border-radius的值是百分比的话,就相当于盒子的宽度和高度的百分比。我们知道在一个正方形内做一个面积最大的圆形,这个圆的半径就为正方形边长的一半。所以border-radius为50%时,则会形成圆。那么可能有人就会问,border-radius为100%时,对应圆的半径长度不就是正方形的宽高么,这种情况下,为什么还是会形成一个和值为50%一样的圆形呢。
其实这是W3C对于重合曲线有这样的规范:如果两个相邻角的半径和超过了对应的盒子的边的长度,那么浏览器要重新计算保证它们不会重合。下面我们假定一个宽高为100px的正方形A。此时设置border-top-left-radius=100%;则正方形A会变成一个半径为100px的四分之一圆弧。
![](http://s17.mogucdn.com/p2/160828/upload_2f35ccg64fhf62hd9al18ckbbb8g5_167x130.png)
然后我们再给border-top-right-radius=100%。此时相邻的角的半径已经超过了对应的盒子的边的长度。浏览器需要重新计算。重新计算的规则是同时缩放两个圆角的半径知道他们刚好符合这个方形。
![](http://s16.mogucdn.com/p2/160828/upload_791elhef7ih6jlb8l5kl79096a2ij_141x128.png)
也就是说如果相邻圆角的半径都被设置成了大于50%,那浏览器会根据图形的实际情况做一些计算。保证圆角能够刚好适应图形。
建议使用border-radius = 50% 来避免浏览器不必要的计算。值得注意的是在涉及到与圆角相关动画的情况下,值为50%和100%,在动画效果上会有不同。例子
border-radius的值是百分比的话,就相当于盒子的宽度和高度的百分比。我们知道在一个正方形内做一个面积最大的圆形,这个圆的半径就为正方形边长的一半。所以border-radius为50%时,则会形成圆。那么可能有人就会问,border-radius为100%时,对应圆的半径长度不就是正方形的宽高么,这种情况下,为什么还是会形成一个和值为50%一样的圆形呢。
其实这是W3C对于重合曲线有这样的规范:如果两个相邻角的半径和超过了对应的盒子的边的长度,那么浏览器要重新计算保证它们不会重合。下面我们假定一个宽高为100px的正方形A。此时设置border-top-left-radius=100%;则正方形A会变成一个半径为100px的四分之一圆弧。
![](http://s17.mogucdn.com/p2/160828/upload_2f35ccg64fhf62hd9al18ckbbb8g5_167x130.png)
然后我们再给border-top-right-radius=100%。此时相邻的角的半径已经超过了对应的盒子的边的长度。浏览器需要重新计算。重新计算的规则是同时缩放两个圆角的半径知道他们刚好符合这个方形。
![](http://s16.mogucdn.com/p2/160828/upload_791elhef7ih6jlb8l5kl79096a2ij_141x128.png)
也就是说如果相邻圆角的半径都被设置成了大于50%,那浏览器会根据图形的实际情况做一些计算。保证圆角能够刚好适应图形。
建议使用border-radius = 50% 来避免浏览器不必要的计算。值得注意的是在涉及到与圆角相关动画的情况下,值为50%和100%,在动画效果上会有不同。例子
相关文章推荐
- border-radius:50%和100%究竟有什么区别
- border-radius:50%和100%究竟有什么区别
- CSS border-radius:50%和100%的区别
- border-radius 50%和100%的区别
- 浅谈为什么border-radius设置成50%~100%都能画圆
- 黑马程序员_"=="和equals方法究竟有什么区别?
- "=="和equals方法究竟有什么区别?
- PCDATA和CDATA的区别究竟是什么呢?
- Java程序员成长之路(接口与抽象类究竟有什么区别)
- "=="和equals方法究竟有什么区别
- Http与Socket连接究竟有什么区别
- "=="和equals方法究竟有什么区别?
- 堆和栈究竟有什么区别
- "=="和equals方法究竟有什么区别?
- "=="和equals 方法究竟有什么区别?
- "=="和equals方法究竟有什么区别
- PCDATA和CDATA的区别究竟是什么呢?
- 装箱、转型、方法调用他们究竟有什么区别?
- “==”和equals方法究竟有什么区别?
- java基础问题----"=="和equals方法究竟有什么区别