详解CSS中的百分比的应用
前言
百分比的应用随处可见,但是就一直没有机会去好好总结一下,如今项目中遇到的坑都是当年留的泪,在月底之前终于把这个好久想总结的文章给写完了。
1、使用百分比的场合
在目前项目中,最常用百分比的莫过于width
和height
。其他可以用到百分比的样式包括:border-radius
,background-position
,font-size
,line-height
,vertical-align
,bottom、left、right、top
,transform: translate
等。如果上面列举的所有属性你都能够轻松地说出它们的百分比含义,那么估计这篇文章就不大适合你了。
接下去我们使用JsFiddle上面的demo来逐个说说这些样式的百分比
2、罗列常用的百分比
2.1、width
和height
这个最常用也是最简单的了,它们的百分比计算是基于包裹它的父元素的宽和高来计算,比如:
其盒子模型如图所示:
有一种特殊情况是,父元素没有明确的高度定义,并且子元素使用百分比并且不是绝对定位,那么这时候的百分比等同于auto
。
于是我们有如下的demo:
可以看到父元素的高度是子元素撑起来的,然后子元素的高度不再按照百分比来计算,而是使用了auto
值。
另外如果子元素是绝对定位的又会如何?再看下面的demo:
那么留给大家一个问题: 此时为什么cube
的这个块元素的高度计算成了101.89?
2.2、margin
和padding
这两个属性的百分比就比较有意思了,也是我们经常用错的两个。在CSS盒子模型规范明确提出了其百分比的含义:
The percentage is calculated with respect to the width of the generated box's containing block. Note that this is true for 'margin-top' and 'margin-bottom' as well. If the containing block's width depends on this element, then the resulting layout is undefined in CSS 2.1.
padding
的解释也是类似。
上面的意思可以总结出三点:
- 百分比的计算是基于其包含块的宽度
- 百分比的计算规则适用于
margin
和padding
的四个方向 - 如果包含块的宽度取决于该元素,那么百分比的使用结果是未定义的。
同样以上面的demo为例子,可以看到cube
元素的margin计算得到:
6px 18px 6px 18px
padding
同理计算得到0px 12px 0px 12px
这时定有童鞋会疑惑,为什么CSS规范的制定者会选择使用包含块的宽度来作为参考值,而不是高度?
其实在上面总结的三点中已经有所涉及的了,在我们平时的样式布局中,元素的高度取决于子元素的高度,如果子元素的margin
或者padding
的百分比又依赖于包含块的高度,那么二者互相依赖,就永远无法得到一个稳定的值,陷入了一种死循环,因此也许是基于这个考虑,CSS的规范中才会提到上面要点的第三点。以上纯属自己的猜测,仅供参考。
2.3、border-radius
根据MDN-border-radius的百分比介绍:
横轴上的百分比参考的是元素自身的宽度,纵轴上的百分比参考的是元素自身的高度,负值是无效的
border-radius
的百分比参考值是自身的尺寸,于是你可以经常使用百分比来画出一个圆形来:
从上面的例子可以看出border-radius
的作用顺序是从top-left
开始顺时针依序到bottom-left
,缩写规则和margin
一样
如图所示:
那么如何理解MDN的那一句话呢?
2.4、background-position
background-position
这个属性允许你在它的包含块中随意移动背景图片(或者渐变),默认值是0 0
,这个时候的图片是放在左上角的位置,如下demo:
如果使用百分比,那么百分比的计算应该是这样的,假设一个容器的长宽为300X200,图片是150X150,那么当设置background-position: 20% 100%
,那么图片新的位置应该是(以左上角为例):
(0, 0) => ((400 - 150) * 20%, (200 - 150) * 100%)
也就是移动的结果是(父元素-背景图片)*百分比
,这样的设计很符合我们平时排版的思路。
2.5、font-size
这个属性的百分比参考值是它的父元素的font-size
,没有太多的信息,是比较纯粹的一个百分比。
2.6、line-height
line-height
这个属性的百分比参考的是自身的font-size
大小,更多line-height
的信息可以参考line-height
2.7、vertical-align
vertical-align
顾名思义是纵向对齐,其参考值是自身的line-height
,这三个属性合起来有一个demo可以看看效果:
2.8、bottom、left、right、top
定位使用的四个方向值,如果使用百分比的话,参考的是元素包含块的尺寸,这个时候不同于margin
或padding
,left
和right
是参照包含块的宽度,bottom
和top
是参照包含块的高度,我们可以通过下面的demo来看看效果:
2.9、transform: translate
在水平或者垂直居中的应用场景中,我最常使用的便是这个平移变换了,轻轻松松的-50%
就可以让块元素居中,那么这个百分之50%
基于的是什么样的参考值呢?答案便是其自身元素的宽度或者高度,这里的宽度和高度是否包含了padding和border呢?我们使用下面的demo来说说:
所以通过这个实例,我们清楚其参考的应该是border-box
的尺寸
Tips
请注意,当百分比值用于可继承属性时,只有结合参照值计算后的绝对值会被继承,而不是百分比值本身。
3、参考
公众号关注一波~
网站源码:linxiaowu66 · 豆米的博客
Follow:linxiaowu66 · Github
关于评论和留言
如果对本文 详解CSS中的百分比的应用 的内容有疑问,请在下面的评论系统中留言,谢谢。