Web布局:display属性
特别声明:为感谢社区广大朋友对小站的支持,自2019年10月1日至2019年11月11日开通年费VIP通道,年费价格为 ¥299.00元。如果您喜欢小站的内容,可以点击开通会员进行全站阅读。如果您对付费阅读有任何建议或想法,欢迎发送邮件至: airenliao@gmail.com!(^_^)
经过CSS盒模型和视觉格式化模型两个章节中的学习,我们有了一个清晰的概念。即在CSS中插何一个元素都是一个盒子,甚至是文本节点也是一个盒子(匿名盒子);都有自己的视觉格式化(不同的盒子)。而其中CSS的display
属性又可以显式的修改每个盒子的视觉格式化模型,比如说从行内级盒子变成块级盒子。那在这一章节中,我们就来一起探讨CSS的display
属性,该属性也是学习CSS不可或缺的属性之一。
display
的基本介绍
CSS的display
属性在W3C规范中是一个独立的模块,即CSS Display Module Level 3。该模块描述如何从文档树(DOM树)生成CSS树(CSSOM树),并定义了如何使用display
属性来控制CSSOM。比如我们一个类似下面这样的一个HTML文档:
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width,initial-scale=1">
<link href="style.css" rel="stylesheet">
<title>Critical Path</title>
</head>
<body>
<p>Hello <span>web performance</span> students!</p>
<div><img src="awesome-photo.jpg"></div>
</body>
</html>
该文档结构很简单,只包含了一些文本和一幅图片。如果你了解如何的渲染原理的话,能了解得到,浏览器大概是像下面这样处理该HTML页面:
忽略其他部分,此处只关注DOM构建这部分。
由于HTML标记定义了不同标记(标记指的是HTML的元素标签)之间的关系(一些标记包含在其他标记内),创建的对象链接在一个树数据结构内,此结构也会捕获原始标记中定义的父子关系,比如<html>
对象是<body>
对象的父元素,<body>
是<p>
对象的父元素,依此类推:
整个流程的最终输出是我们这个简单页面的文档对象模型 (DOM),浏览器对页面进行的所有进一步处理都会用到它。
在该示例中,我们使用<link>
标签引入了一个style.css
样式文件,该文件中的样式代码假设如下:
body {
font-size: 16px
}
p {
font-weight: bold
}
span {
color: red
}
p span {
display: none
}
img {
float: right
}
与处理 HTML 时一样,我们需要将收到的 CSS 规则转换成某种浏览器能够理解和处理的东西。因此,我们会重复 HTML 过程,不过是为 CSS 而不是 HTML:
CSS 字节转换成字符,接着转换成令牌和节点,最后链接到一个称为“CSS 对象模型”(CSSOM) 的树结构内:
浏览器会将DOM树和CSSOM树合并成一个渲染树(Render Tree):
有了渲染树,我们就可以进入“布局”阶段。
在CSS中,对于每个元素,CSS会根据元素的display
属性生成零个或多个框(盒子)。通常,元素生成一个单独的框(盒子),即主体框,表示的是元素自己,并会在框树中包含其内容。然而,一些display
的值(比如display: list-item
)会生成多个框(一个主体框和一个Marker标记框);有些值(比如display: none
或display:contents
)会导到元素或其后代元素不会生成任何框。简单地说,元素的框类型是由display
的属性值来决定。比如大家最常为熟悉的display:block
会让元素生成一个块级框,display:inline
会让元素生成一个行内级框。
有关于框(或者盒子)的介绍,可以阅读视觉格式化模型一章。
如果用一句话来描述的话,那就是CSS的display
属性可以用来改变元素的视觉格式化模型,即改变框的类型。
display
的基本属性
display
属性定义了一直元素的显示类型(视觉格式化模型)。默认情况之下,浏览器都会对元素设置一个display
的值,比如上面示例中的<p>
元素:
如需转载,烦请注明出处:https://www.w3cplus.com/css/web-layout-css-display.html
如果文章中有不对之处,烦请各位大神拍正。如果你觉得这篇文章对你有所帮助,打个赏,让我有更大的动力去创作。(^_^)。看完了?还不过瘾?点击向作者提问!