资讯专栏INFORMATION COLUMN

【Hello CSS】第六章-文档流与排版

null1145 / 2072人阅读

摘要:作者陈大鱼头正常流什么是正常流其实就是我们日常所说的文档流。在官方文档里对应的是。然后,包含形成一条线的框的矩形区域称为线盒。基线线盒的高度由的计算结果决定。级层叠上下文被自动视为父级层叠上下文的一个独立单元。自由分配,由具体情况决定。

作者:陈大鱼头

github: KRISACHAN

正常流
什么是“正常流”?
其实就是我们日常所说的“文档流”。
W3C官方文档里对应的是“normal flow”。

正常流的盒子属于格式化上下文(FC),在CSS2.2中可以是表格内联
CSS3中引入了flexgrid,当然以后会引入得更多。

块级盒子(block-level boxes) 与创建 块级格式化上下文(BFC) 有关;

行内级盒子(inline-level boxes) 与创建 行内级格式化上下文(IFC) 有关。

BFC

鱼头注:在之前的文章中有介绍过如何生成一个BFC,本章便不再累述。

根据W3C上的解释:

浮动、绝对定位元素、块容器(例如inline-blocks、table-cells、and table-captions)都不是块盒子。除了overflow以外的visible(除非该值已经传播到了视口)为其内容建立新的BFC

表现是什么?

表现就是在包含块内一个盒子一个盒子不重叠地垂直排列,两个兄弟盒子直接的垂直距离由margin决定。浮动也是如此(虽然有可能两个盒子的距离会因为floats而变小),除非该盒子再创建一个新的BFC

简单来说,BFC就是一个独立不干扰外界也不受外界干扰的盒子啊(/ω\)

IFC

鱼头注:Mmmmm,BFC还是相对好理解,IFC比较复杂,W3C上所占的篇幅也比BFC多得多的。

简单来说,跟BFC表现不一样的盒子就是IFC了(*❦ω❦)。

BFC不一样,IFC内的盒子会从包含块的顶部一个接着一个地水平排列。这些盒子会考虑水平marginborderpadding。垂直对齐的方式也略有复杂。然后,包含形成一条线的框的矩形区域称为线盒(line box)

线盒(line box)的宽度:由浮动情况跟它所在的包含块决定。

线盒(line box)的高度:由line-height的计算结果决定。

基线(baseline)

线盒(line box) 的高度由line-height的计算结果决定。

line-height的定义就是线盒(line box)内两基线(baseline)(W3C原文)的间距。

vertical-align的默认值就是基线。

字母x

你们还记得读书时用的英语作业本吗?

如上图所示,我们看到小写字母x的位置,它的上下边缘就是我们的基线(baseline),但下边缘才是我们日常使用的属性值。顺便一提,CSS单位ex便是指的这个字母x的高度。

如何理解IFC

自从翻了CSS的发展史之后,了解了CSS的诞生背景之后,其实很多东西理解起来就轻松了。IFC之所以比BFC复杂,原因就在于很多非规律的成分,在西文了,我们可以简单粗暴的理解为英语作业本的表现,但是在writing-mode不同,文字表现不同的各个国家,IFC的表现也会有差异。

当然以上都是我的个人理解,如果有更科学更标准的理解方式或者不同的想法,可以加鱼头微信“krisChans95”来探讨。

层叠上下文与层叠顺序

我们首先来看一张很著名的图

上面便是在同样的上下文中,元素的层叠规则(CSS3以后的除外,那规则会比较复杂)。元素的 z-index 值只在父级层叠上下文中有意义。级层叠上下文被自动视为父级层叠上下文的一个独立单元。

文档中的层叠上下文由满足以下任意一个条件的元素形成:

根元素 (HTML),

z-index 值不为 auto 的 绝对/相对定位,

一个 z-index 值不为 auto 的 flex 项目 (flex item),即:父元素 display: flex|inline-flex

opacity 属性值小于 1 的元素,

transform 属性值不为 none 的元素,

mix-blend-mode 属性值不为 "normal"的元素,

filter值不为 none 的元素,

perspective值不为 none 的元素,

isolation 属性被设置为 isolate 的元素,

position: fixed

will-change 中指定了任意 CSS 属性,即便你没有直接指定这些属性的值

-webkit-overflow-scrolling 属性被设置 touch 的元素

新时代的布局 Flex

我想到如今,应该很少人会没写过或者没了解过 Flex (不知道的可以翻阅MDN)。

这个是 CSS 史上第一个以 start-end 来定义方向的属性,这是一个可伸缩的布局模型。

一个设有 display:flexdisplay:inline-flex 的元素是一个伸缩容器,伸缩容器的子元素被称为为伸缩项目,这些子元素使用伸缩布局模型来排版。

语法如下:

display: flex/inline-flex;
flex: none | [ <"flex-grow"> <"flex-shrink">? || <"flex-basis"> ];

flex 属性可以指定1个,2个或3个值。

单值语法: 值必须为以下其中之一:

一个无单位 数() : 它会被当作的值

一个有效的 宽度(width) 值: 它会被当作 的值

关键字 noneauto, 或 initial

双值语法: 第一个值必须为一个无单位数,并且它会被当作 的值。第二个值必须为以下之一:

一个无单位数:它会被当作 的值。

一个有效的宽度值: 它会被当作 的值。

三值语法:

第一个值必须为一个无单位数,并且它会被当作 的值。

第二个值必须为一个无单位数,并且它会被当作 的值。

第三个值必须为一个有效的宽度值, 并且它会被当作 的值。

Grid

我印象中第一次接触Grid布局的时候,开个Chrome的实验性功能也就只能能支持个repeat(4, 200px),但如今已经除了IE,其他浏览器差不多也是Full support了(如果你还不了解这个布局模型,可以翻阅MDN)。

在这里顺便提一下,Flex是一维布局,Grid是二维布局。意思就是Flex只能同时在一个方向进行作用,而Grid却可以在纵横两个方向同时工作。

语法如下:

display: grid/inline-grid;
gird: <"grid-template"> | <"grid-template-rows"> / [ auto-flow && dense? ] <"grid-auto-columns">? | [ auto-flow && dense? ] <"grid-auto-rows">? / <"grid-template-columns">

我们来看看 grid 所支持的一些 “奇怪” 的特性:

命名空间

鱼头觉得 grid 布局中最有趣的功能就是命名空间了,我们可以看看以下示例:

首先是第一种 网格线命名



    

效果如下:

第二种 真命名空间布局



    

效果如下:

通过上面两个示例,我们可以发现Grid布局的二维性可以满足我们日常很多的布局要求,当然,第一眼看语法不免有点懵,但是熟悉之后,基本日常需求中的二维布局我们都能依赖它来完成。

一些常用的灵活尺寸
属性 定义
fr 可伸缩长度单位,网格容器中可用空间的一等份。
auto 自由分配,由具体情况决定。
minmax() 定义了一个长宽范围的闭区间。
fit-content() 同等于min(maximum size, max(minimum size, argument))

以上属性对比结果如下:

源码在我codepen中,大家可以自行去对比:
https://codepen.io/krischan77...

后记

本章的内容要深究起来是非常庞大的,鱼头我在准备内容的时候有想过是不是要另外再开个布局的系列去分享,但是我想把本文当成是一个关键字集合来供自己以及有需要的人来做目录也是极好的。我认为CSS中最难的部分就是布局了,虽然W3C本身提供了很多的属性以及规范来处理这些布局问题的,但是涉及到了现实的项目,更多时候是错综复杂的,但是随着CSS逻辑属性的变化,以及各类新布局系统的出现,相信以后的布局会简单得多。

本章内容就这么草草结束了,关于上面提到的,或者没有提到的与之相关的,以后有机会鱼头会新开个系列来分享。当然如果看到这里的你有任何布局上的见解或问题也欢迎来找鱼头探讨。

参考资料:

聊聊CSS中的层叠相关概念

CSS Conf -《新时代CSS布局》学习总结

新时代CSS布局

CSS世界

CSS Display Module Level 3

CSS Flexible Box Layout Module Level 1

CSS Grid Layout Module Level 1

CSS Box Alignment Module Level 3

写给自己看的display: grid布局教程

写给自己看的display: flex布局教程

CSS深入理解流体特性和BFC特性下多栏自适应布局

块格式化上下文

Normal flow

css中的IFC

【Hello CSS】系列

【Hello CSS】是以CSS基础概念为主题的系列文章,旨在帮助大家更深刻地了解并且提高CSS在各位开发者心目中的地位。由于鱼头我水平有限,文笔有限,如果各位在文章中发现有任何不合理,不正确的地方,还烦不吝指出,我会非常感谢的;如果通过文章有任何想法或疑问,也希望各位能积极留言,我们互相探讨;如果通过本系列文章有所收获,这就让鱼头我喜不自胜了!

如果你也喜欢 CSS,喜欢探讨技术,或者对本文,本系列有任何的意见或建议,你可以扫描下方二维码,关注微信公众号“ 鱼头的Web海洋 ”,随时与鱼头互动。欢迎!衷心希望可以遇见你。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/115006.html

相关文章

  • Hello CSS六章-文档流与排版

    摘要:作者陈大鱼头正常流什么是正常流其实就是我们日常所说的文档流。在官方文档里对应的是。然后,包含形成一条线的框的矩形区域称为线盒。基线线盒的高度由的计算结果决定。级层叠上下文被自动视为父级层叠上下文的一个独立单元。自由分配,由具体情况决定。 作者:陈大鱼头 github: KRISACHAN 正常流 什么是正常流?其实就是我们日常所说的文档流。在W3C官方文档里对应的是normal ...

    nihao 评论0 收藏0
  • 《On Java 8》中文版,又名《Java 编程思想》中文第五版

    摘要:基于版本基于版本。由于中英行文差异,完全的逐字逐句翻译会很冗余啰嗦。译者在翻译中同时参考了谷歌百度有道翻译的译文以及编程思想第四版中文版的部分内容对其翻译死板,生造名词,语言精炼度差问题进行规避和改正。 来源:LingCoder/OnJava8 主译: LingCoder 参译: LortSir 校对:nickChenyx E-mail: 本书原作者为 [美] Bru...

    BingqiChen 评论0 收藏0
  • 《Python基础教程》六章--读书笔记

    摘要:第六章抽象本章会介绍如何将语句组织成函数。关键字参数和默认值目前为止,我们使用的参数都是位置参数,因为它们的位置很重要,事实上比它们的名字更重要。参数前的星号将所有值放置在同一个元祖中。函数内的变量被称为局部变量。 第六章:抽象 本章会介绍如何将语句组织成函数。还会详细介绍参数(parameter)和作用域(scope)的概念,以及递归的概念及其在程序中的用途。 懒惰即美德 斐波那契数...

    AnthonyHan 评论0 收藏0
  • [CSS]《CSS揭秘》六章——用户体验

    摘要:定义和用法标签为元素定义标注标记。元素不会向用户呈现任何特殊效果。不过,它为鼠标用户改进了可用性。就是说,当用户选择该标签时,浏览器就会自动将焦点转到和标签相关的表单控件上。 选用合适的鼠标光标 #testdiv{ cursor:not-allowed; /* cursor:none;//例如视频界面隐藏鼠标 */ } 扩大可点击区域 .testdiv{...

    simon_chen 评论0 收藏0
  • 《 JavaScript程序设计》—— 六章 事件

    摘要:当这些系统的用户界面元素产生某些事件时,会运行特定的代码以作响应。我们将注意力放在程序设计上,特别是放在事件驱动的程序设计上,所以重点还在。 6.1 6.1.1 在研究受事件驱动的程序时,倾向于关注四个机制 因为许多事件都与人们可以看到的用户界面元素(按钮、文本字段、滑动块)相关联,所以事件驱动计算的一个关键要素就是用于定义用户界面元素的机制 由于检测到的事件经常会引用或修改一个脚本...

    mj 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<