border-radius 值类型-百分比

 border-radius的值是百分比的话,就相当于盒子的宽度和高度的百分比
 我们知道在一个正方形内做一个面积最大的圆形,这个圆的半径就为正方形边长的一半。所以border-radius为50%时,则会形成圆。那么可能有人就会问,border-radius为100%时,对应圆的半径长度不就是正方形的宽高么,这种情况下,为什么还是会形成一个和值为50%一样的圆形呢。

  其实这是W3C对于重合曲线有这样的规范:如果两个相邻角的半径和超过了对应的盒子的边的长度,那么浏览器要重新计算保证它们不会重合。下面我们假定一个宽高为100px的正方形A。此时设置border-top-left-radius=100%;则正方形A会变成一个半径为100px的四分之一圆弧。

  然后我们再给border-top-right-radius=100%。此时相邻的角的半径已经超过了对应的盒子的边的长度。浏览器需要重新计算。重新计算的规则是同时缩放两个圆角的半径知道他们刚好符合这个方形。 也就是说如果相邻圆角的半径都被设置成了大于50%,那浏览器会根据图形的实际情况做一些计算。保证圆角能够刚好适应图形。

建议+举例

  • 建议使用border-radius = 50% 来避免浏览器不必要的计算。
  • 值得注意的是在涉及到与圆角相关动画的情况下,值为50%和100%,在动画效果上会有不同。
  • 举例:http://jsbin.com/ruzizo/edit?html,css,output

最新文章

  1. Difference between WCF and Web API and WCF REST and Web Service
  2. ASP.net MVC 学习笔记(一)-一些不同点
  3. Spring原理解析-利用反射和注解模拟IoC的自动装配
  4. C++小项目:directx11图形程序(七):modelclass
  5. 零基础十分钟学会用git在coding.net上传(pull)和push
  6. JAVA的包装类 【转】
  7. python os&shutil 文件操作
  8. 食物链(codevs 1074)
  9. 【POJ】3070 Fibonacci(矩阵乘法)
  10. 最火的Android开源项目(一)
  11. Http请求 post get
  12. JSP之JavaBean
  13. Java多线程由易到难
  14. centos vsftpd 553 Could not create file解决方法
  15. javascript小记一则:今天在写VS2005——.NET程序时,写的一个JS图片示例案例
  16. golang协程踩坑记录
  17. MFC 中MessageBox 显示在所有窗口的最上面
  18. 『TensorFlow』数据读取类_data.Dataset
  19. php 去除所有空格 包括中文空格圆角空格
  20. Javascript Get or Set Checked Radio Value

热门文章

  1. python_day1(初始Python)
  2. PHP判断是否关注微信公众号
  3. PHP-PSR 现代PHPer的开发规范
  4. 020.掌握Pod-Pod基础使用
  5. hdu 4337 King Arthur's Knights (Hamilton)
  6. nyoj 242-计算球体积 (pi*r*r*r*4/3)
  7. JQury自动切换图片
  8. php Swoole实现毫秒级定时任务
  9. python_08
  10. 给公司写的composer包开发的规范