摘要:内容块定义通常情况下,元素的大小和位置都取决他的内容块。一般地,内容块是该元素最近的块级父元素,但有一些例外情况。依据内容块的值进行百分比计算。的祖先元素均是,所以浏览器窗口才成为了其内容块。
position
我们都知道元素都拥有 position 这个css属性,先来看看他的基本定义和可用值。
定义position 决定了元素位置是如何被渲染的
可用值值 | 描述 |
---|---|
static | 默认值,元素在文档流中依次渲染 |
absolute | 元素位置相对于其最近的非 static 的父元素 |
fixed | 元素位置相对于浏览器窗口 |
relative | 元素位置相对于原本应该渲染的位置 |
sticky | 根据滚动的位置在 relative 和 fixed 之间切换 |
initial | 设置为默认值 |
inherit | 从父元素继承 |
This is a paragraph!
body { background: beige; } section { display: block; width: 400px; height: 160px; background: lightgray; } p { width: 50%; /* == 400px * .5 = 200px */ height: 25%; /* == 160px * .25 = 40px */ margin: 5%; /* == 400px * .05 = 20px */ padding: 5%; /* == 400px * .05 = 20px */ background: cyan; }
很好,与我们期望的一样渲染出来了。现在我们把 section 的 display 属性 换成 inline
section { display: inline; width: 400px; height: 160px; background: lightgray; }
这个破坏真是立竿见影啊,为什么会这样呢?要知晓其中的奥秘,就要了解什么是内容块。
内容块 定义通常情况下,元素的大小和位置都取决他的内容块。一般地,内容块是该元素最近的块级父元素,但有一些例外情况。
为什么内容块很重要元素的大小和位置都是由其内容块做为参考的,他会影响到元素的 width, height, padding, margin 还有 offset 相关的属性。
如何找到元素对应的内容块position 是 static 或者 relative 时,其内容块是其最近的块级父元素的内容框(content-box),比如 block, inline-block, list-item,或者是被指定为某种格式容器的元素,比如 table, flex, grid。
position 是 absolute 时,其内容块是其最近的 position 不是 static 的块级父元素的填充框(padding-box)。
position 是 fixed 时,其内容块是整个视图窗口(viewport)
position 是 absolute 或者 fixed 时,其内容块也可能是有下列特殊情况的最近的父元素的填充框(padding-box)。
transform 或者 perspective 被设置过或将被设置不为 none。
filter 被设置或将被设置不为 none。
从内容块计算百分比height, top 和 bottom 依据内容块的 height 值进行百分比计算。如果内容块是 static 或者 relative,并且没有设置高度,依靠其内容决定高度,那么这些值都会变成 0。
width, left, right, padding, margin 依据内容块的 width 值进行百分比计算。
例子解释现在我们了解了内容快的概念之后,再来看看上面的例子,p 最近的父元素是 section, 被设置为 inline 之后不再是块级元素,所以 body 变成了离 p 最近的块级父元素,此时内部的百分比计算都依据 body 的宽高做对应计算。
absolute的用例我们再看看别的例子
现在我们将第一个例子中的 p 的 position 设置为 absolute, section 从 inline 改回 block,
body { background: beige; } section { display: block; width: 400px; height: 160px; background: lightgray; } p { position: absolute; width: 50%; /* == 浏览器宽度的50% */ height: 25%; /* == 浏览器高度的25% */ margin: 5%; /* == 浏览器宽度的5% */ padding: 5%; /* == 浏览器宽度的5% */ background: cyan; }
由于 p 设置为了 absolute, 显而易见他的大小尺寸都根据了浏览器窗口来计算,注意这里也经历了寻找内容块的过程。p 的祖先元素均是 static,所以浏览器窗口才成为了其内容块。
现在我们还不错,一切都在掌握之中,我们试着把 section 的 transform 设置为 rotate(0deg),旋转了 0 度,可以预计到本来应该没有视觉上的效果,但这么做会影响对内容块的决定,从而导致 p 的大小和位置变化。
section { transform: rotate(0deg); width: 400px; height: 160px; background: lightgray; } p { position: absolute; ... }
看!由于我们为 section 设置了 transform,p 的内容块不再是浏览器窗口了,而是 section。
总结css 的世界就是这么奇妙,表面上看上去酷炫多彩,内心维护着自己的规则世界。有时候产生了一些让人疑惑不解的 bug ...不过,通过探究其本质,迷雾终会散尽,bug 总会改完的。
希望大家都 get 到了新技能,下回再见!
首发于自己的 github/kimochg/TinyThoughts
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/112990.html
摘要:看上面的例子我们也能看出来,实际上一个内联元素是有两个高度的高度实际渲染的那个高度和高度实际区域占空间的高度也就是。 前言 总括: 本文通过实例讲解CSS中最大的难点之一,行内元素的布局,主要是挖掘line-height和vertical-align两个属性在布局方面的使用。 原文博客地址:深入理解行内元素的布局 知乎专栏&&简书专题:前端进击者(知乎)&&前端进击者(简书) 博...
摘要:看上面的例子我们也能看出来,实际上一个内联元素是有两个高度的高度实际渲染的那个高度和高度实际区域占空间的高度也就是。 前言 总括: 本文通过实例讲解CSS中最大的难点之一,行内元素的布局,主要是挖掘line-height和vertical-align两个属性在布局方面的使用。 原文博客地址:深入理解行内元素的布局 知乎专栏&&简书专题:前端进击者(知乎)&&前端进击者(简书) 博...
摘要:而在文档流中,如果浮动元素和跟随元素都是元素,它们两在默认情况下都将占据一行。而由于浮动元素脱离了文档流,如果父元素没有指定高度或者其他元素撑起,也就出现了所谓的浮动元素的父元素高度塌陷。 为什么要写《重塑你的CSS世界观》系列文章 由于从工作到现在,我的主要工作都是写JavaScript,几乎没怎么碰CSS,通常都是别人写好界面,然后我来开发JavaScript逻辑代码,这导致了严重...
摘要:而在文档流中,如果浮动元素和跟随元素都是元素,它们两在默认情况下都将占据一行。而由于浮动元素脱离了文档流,如果父元素没有指定高度或者其他元素撑起,也就出现了所谓的浮动元素的父元素高度塌陷。 为什么要写《重塑你的CSS世界观》系列文章 由于从工作到现在,我的主要工作都是写JavaScript,几乎没怎么碰CSS,通常都是别人写好界面,然后我来开发JavaScript逻辑代码,这导致了严重...
阅读 3060·2021-11-23 09:51
阅读 1039·2021-09-02 15:21
阅读 3003·2019-08-30 13:56
阅读 1827·2019-08-29 14:12
阅读 705·2019-08-29 13:53
阅读 1662·2019-08-29 11:32
阅读 1323·2019-08-29 11:25
阅读 1491·2019-08-28 17:51