前端Tips#3 - 简写的 border-radius 100% 和 50% 是等效的
2020/1/9 14:01:25
本文主要是介绍前端Tips#3 - 简写的 border-radius 100% 和 50% 是等效的,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
本文同步自 JSCON简时空 - 技术博客,点击阅读
视频讲解
【 视频地址 】
文字讲解
1、先讲结论
border-radius
这个 css 属性大家应该使用得非常娴熟,现实中用到的场景基本都是四个圆角一致的情况。
比如实现一个圆形按钮,其中 border-radius
数值有些人写为 50%
,有些人则写成 100%
,不过你会发现两者效果是一样的:
测试 HTML 代码如下:
<style> .circle-btn { color: white; width: 100px; height: 100px; text-align: center; line-height: 100px; } </style> <div class="circle-btn" style=" background: #8BC34A; border-radius: 100%; ">50%</div> <div class="circle-btn" style=" background: #E91E63; border-radius: 100%; ">100%</div>
其实不论是 50%
还是 100%
,只要将 border-radius
设置成 x%
,且 x >= 50
都能获得和 50%
一样的效果。
如果不知道其中的原因,可以继续往下看。
2、原因分析
第 1 个知识点是 border-radius
的写法,最全的写法是这样的,记住这张图就行:
详细教程可参考《CSS Border-Radius Can Do That?》
第 2 个知识点是 border-radius
的标准,在border-radius
标准中 Overlapping Curves 章节里,有这么一段话:
简单翻译为:角曲线不得重叠:当任意两个相邻边框半径的总和超过边框的长度时,UA(标准实现方)必须按比例减少所有边框半径的使用值,直到它们没有重叠
我们知道两个前提:
- 每一条边最高可用长度也就 100%;
- 每一条边最多可以设置两个圆角曲线(在边的两端)
这两端的椭圆半轴长度设置值之和存在两者情况:
- 设置值加起来不超过 100%,那么大伙儿各自安好,互不干扰;
- 设置值加起来如果超过 100%,那需要按比例重新划分:比如一个设置 100%,一个设置成 300%,加起来就 400% 了(超过 100% 了) —— 那么实际上一个真正分得长度的 1/4,另一个真正分得长度的 3/4;
结合 知识点 1 和 知识点 2 就能得到文章最开始的结论了。
3、小工具 + 小练习
如果对 border-radius
的写法不太熟也没关系,有个在线工具可以帮你更好的理解。
另外,最近看到使用单个 div + border-radius
实现以下 “转动的太极图”,大伙儿可以练习一下:
具体实现可参考以下任意一篇文章:
- How to create a yin-yang symbol with pure CSS:使用一个 div 元素纯 CSS 实现 “阴阳” 圆形,附 源码
- 利用CSS3的border-radius绘制太极及爱心图案示例:使用 border-radius 绘制太极和爱心
- CSS画各种图形(五角星、吃豆人、太极图等):更多练手的 css 项目
也可以参考我所 “抄写” 的代码
4、参考文章
- MDN border-radius: MDN 文档
- Spec border-radius: CSS3 中 border-radius 的规范
- CSS Border-Radius Can Do That?:强烈推荐这篇文章(附中文译文),图文并茂,还带一个可视化工具
- Fancy-Border-Radius:这个就是上一条所指的在线 border radius 工具,所见即所得的;边动手边学习,理解会快很多
- 秋月何时了,CSS3 border-radius知多少?:张鑫旭教程,行文幽默,讲解清晰详细
- 了解 border-radius 的原理:用例子讲解 border-radius 的原理
- CSS border-radius:50%和100%的区别:本文主要是讨论 50% 和 100% 的设置值一样的原因
- border-radius:专门生成 border-radius CSS3 代码的网站,也是所见即所得
关于 “前端Tips专栏”
“前端Tips”专栏,隶属于 JSCON 专栏系列,设计初衷是快速获取前端小技巧知识,取材广泛,涵盖前端编程诸多领域。设计初衷是快速消费类知识,所以每个 tips 阅读耗时大约 5 分钟。为方便读者在不同场合阅读,每篇 tips 配有视频、音频和文字,挑自己喜欢方便的就行。
有两种方式获取历史 tips:
① 在公众号内回 "tips" +"期号" 就可以。例如:回复 “tips25” 即可获取第25期 tips
② 前往网站:https://boycgit.github.io/fe-... ,里面提供了搜索功能
欢迎大家关注我的知识专栏,更多内容等你来挖掘
这篇关于前端Tips#3 - 简写的 border-radius 100% 和 50% 是等效的的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23实现OSS直传,前端怎么实现?-icode9专业技术文章分享
- 2024-11-22在 HTML 中怎么实现当鼠标光标悬停在按钮上时显示提示文案?-icode9专业技术文章分享
- 2024-11-22html 自带属性有哪些?-icode9专业技术文章分享
- 2024-11-21Sass教程:新手入门及初级技巧
- 2024-11-21Sass学习:初学者必备的简单教程
- 2024-11-21Elmentplus入门:新手必看指南
- 2024-11-21Sass入门:初学者的简单教程
- 2024-11-21前端页面设计教程:新手入门指南
- 2024-11-21Elmentplus教程:初学者必备指南
- 2024-11-21SASS教程:从入门到实践的简单指南