参考答案:
display 属性可以设置元素的内部和外部显示类型。
以下是一些关于display比较常用的属性值:
值 | 描述 |
---|---|
none | 元素不会显示 |
block | 此元素将显示为块级元素,此元素前后会带有换行符。 |
inline | 默认。此元素会被显示为内联元素,元素前后没有换行符。 |
inline-block | 行内块元素。(CSS2.1 新增的值)[IE6/7不支持] |
inline-table | 此元素会作为内联表格来显示(类似 table),表格前后没有换行符。 |
table | 此元素会作为块级表格来显示(类似 table),表格前后带有换行符。 |
inherit | 规定应该从父元素继承 display 属性的值。 |
grid | 网格布局(Grid)是最强大的CSS 布局方案。 它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局。 |
flex | 弹性布局,用来为盒状模型提供最大的灵活性。 |
从大的分类来讲,display
的32
种写法可以分为6
个大类,再加上1
个全局类,一共是7
大类:
所谓外部值,就是说这些值只会直接影响一个元素的外部表现,而不影响元素里面的儿子级孙子级元素的表现。
这个值大家不陌生,我们最熟悉的<div>
缺省就是这个值,最基本的块级元素,属于css
入门初学者都知道的概念,只要是容器类型的元素基本都是这个值。除<div>
之外,还有<h1>
到<h6>
,<p>
,<form>
,<header>
,<footer>
,<section>
,<article>
天生都是这个值。
这个值大家也不陌生,行内元素嘛,只要是个行内元素都是这个值,最典型的是<span>
,还有<a>
,<img>
,以及古代html
语言当中的<b>
,<i>
都属于这一类型。
这个值有点奇怪,通常没人用它,但你可以知道它。因为除了IE
和Opera
支持它以外,其他所有主流浏览器包括Chrome
, Safari
, Firefox
全都对它置若罔闻。这东西说白了也没什么神秘,它的意思就是说如果我们命令一个元素run-in
,中文意思就是『闯入
』!那么这个元素就直接闯入下一行。比如说这样:
写起来大概就是这样:
1<div class="a">aaa</div> 2<div class="b">bbb</div>
1.a { 2 font-size: 36px; 3 display: run-in; 4}
这有什么用呢?我们拿span
设置font-size
一样可以实现这个效果,就让IE
自己跟自己玩去吧!说实话,在人力资源如此宝贵的今天,IE
的产品经理不知脑子是不是进水了,不派工程师去实现那么多比这重要的多得多的特性,却花时间做这么个没用的玩意儿,难道工程师的时间不是金钱吗?难怪市场占有率连年下滑。
谈完了外部值,我们来看看内部值。这一组值比较有意思了,在css3
如火如荼的今天,你要玩不转这些值,怕是哪儿也找不到工作的。内部值主要是用来管束自己下属的儿子级元素的排布的,规定它们或者排成S
形,或者排成B
形这样的。
含义不清,实验室阶段产品,Chrome
不支持。如果还不够说服你暂时不要碰它的话,试着理解以下英文原文:
If its outer display type is inline or run-in, and it is participating in a block or inline formatting context, then it generates an inline box. Otherwise it generates a block container box.
不同于刚才谈到的flow
,现在用flow-root
的渐渐多起来了,因为它可以撑起被你float
掉的块级元素的高度。外容器本来是有高度的,就像这样:
1<div class="container container1"> 2 <div class="item"></div> 3 Example one 4</div>
1.container { 2 border: 2px solid #3bc9db; 3 border-radius: 5px; 4 background-color: #e3fafc; 5 width: 400px; 6 padding: 5px; 7} 8.item { 9 height: 100px; 10 width: 100px; 11 background-color: #1098ad; 12 border: 1px solid #0b7285; 13 border-radius: 5px; 14}
结果因为你想让那一行字上去,于是你给.item
加了一个float: left;
结果就成这样了,外容器高度掉了,这不是很多人常犯的错误吗?
现在我们给.container
加上display: flow-root;
再看一下:
喏,外容器高度又回来了,这效果是不是杠杠的?
可能就有同学要说了,我们用clear: both;
不是一样可以达到这效果吗?
1.container::after { 2 content: ''; 3 clear: both; 4 display: table; 5}
小明,请你出去!我们在讲display: flow-root;
,不是在讲clear: both;
!
这一个属性,以及下面的另外8
个与table
相关的属性,都是用来控制如何把div
显示成table
样式的,因为我们不喜欢<table>
这个标签嘛,所以我们想把所有的<table>
标签都换成<div>
标签。<div>
有什么好?无非就是能自动换行而已,但其实你完全可以做一个<table><tr><td>
标签,把它全都替换成display: block;
也可以自动折行,只不过略微麻烦而已。
关于display: table;
的详细用法,大家可以参考mdn上的文章,这里就不细说了。
敲黑板,划重点!作为新一代的前端工程师,这个属性你必须烂熟于胸中。display: flex;
以及与它相关联的一系列属性:flex-direction
, flex-wrap
, flex-flow
, justify-content
, align-items
, align-content
,并且包括所有这些属性的取值,都是你需要反复研磨的。2009
年诞生的这个属性可以说是不亚于css
界一场蒸汽机诞生一样的工业革命,它的诞生标志着马车一样的float
被彻底抛进历史的垃圾堆。
没有一张图能完整地展现flex
的神韵,就放这张我比较喜欢的图片吧:
会flex
很吊吗?会grid
更吊哦!也许这就是下次前端面试的重点哦!
grid
布局,中文翻译为网格布局
。学习grid
布局有两个重点:一个重点是grid
布局引入了一个全新的单位:fr
,它是fraction
(分数
)的缩写,所以从此以后,你的兵器库里除了px
, em
, rem
, 百分比
这些常见兵器以及vw
, vh
这些新式武器之外,又多了一样旁门暗器fr
,要想用好grid
,必须充分掌握fr
。另一个重点是斜杠操作符
,这可不是分数
哦。它表示的是起始位置
和结束位置
。比如说3 / 4
,这可不是四分之三
的意思,这是指一个元素从第3
行开始,到第4
行结束,但又不包括第4
行。
同样,与grid
相关联的也有一大堆旁门属性,是在学习display: grid;
的同时必须掌握的。包括grid
, grid-column-start
, grid-column-end
, grid-row-start
, grid-row-end
, grid-template
, grid-template-columns
, grid-template-rows
, grid-template-areas
, grid-gap
, grid-column-gap
, grid-row-gap
, grid-auto-columns
, grid-auto-rows
, grid-auto-flow
, grid-column
, grid-row
。不能详述,关于这个写起来又是一大篇文章。详情还是参考 csstrick 上这篇文章,讲得非常细致非常清楚。
ruby
这个取值对于我们亚洲人来说其实是非常有用的一个东西,但是目前除了Firefox
以外其它浏览器对它的支持都不太好。简而言之,display: ruby;
的作用就是可以做出下面这样的东西:
很好的东西,对吧?如果可以用的话,对我国的小学教育可以有极大的促进。但可惜我们现在暂时还用不了。
ruby
这个词在英语里的意思是红宝石
,但在日语里是ルビ
,翻译成中文是旁注标记
的意思,我们中文的旁注标记就是汉语拼音。可以想见,这个标准的制定者肯定是日本人,如果是我们中国人的话,那这个标签就不是ruby
,而是pinyin
了。还有一个ruby
语言,发明者也是一个日本人,和html
里这个ruby
是两码事,不要搞混了。
ruby
的语法大致如下:
subgrid
总的思想是说大网格里还可以套小网格,互相不影响。但如果grid
里可以再套subgrid
的话,那我subgrid
里还想再套subgrid
怎么办?subsubgrid
吗?况且,到底是grid: subgrid;
还是display: subgrid;
这个也没有达成共识。
display: list-item;
和display: table;
一样,也是一帮痛恨各种html
标签,而希望只使用<div>
来写遍一切html
的家伙搞出来的鬼东西,实际使用极少,效果就是这样:
看,你用<ul><li>
能实现的效果,他可以用<div>
实现出来,就是这个作用。
属性值一般是附属于主值的,比如主值里设置了display: table;
,就可以在子元素里使用display: table-row-group;
等等属性,不过并不绝对。关于它们的作用,主要参考主值就够了。
详情参考display: table;。
详情参考display: table;。
详情参考display: table;。
详情参考display: table;。
详情参考display: table;。这个属性有必要详细说说,因为它完全可以单独应用,用在高度不固定元素的垂直居中上。效果如下图所示:
详情参考display: table;。
详情参考display: table;。
详情参考display: table;。
详情参考display: ruby;。
详情参考display: ruby;。
详情参考display: ruby;。
详情参考display: ruby;。
MDN
里把它叫做<display-box> values
(盒子值
),我把它叫做显示值
,主要是为了便于理解。
你给中间那个div
加上display: contents;
之后,它就变成这样了:
这就是display: contents;
的作用,它让子元素拥有和父元素一样的布局方式,仅此而已。
这么著名的值还用多说吗?
关于display: inline-block;
的作用恐怕只要做过3
天以上前端的工程师都应该知道。什么也不说了,上一张著名的图片作总结吧:
你要能理解inline-block
,你就能理解inline-table
。在行内显示一个表格,就像这样:
这个就不用多说了吧?跟上面一样,在行内进行弹性布局,参考display: flex;。
同上,在行内进行网格布局,参考display: grid;。
这些值不是display
属性的专利,几乎其它任意属性都可以用,列在这里凑个数。
继承父元素的display
属性。
不管父元素怎么设定,恢复到浏览器最初始时的display
属性。
unset
混合了inherit
和initial
。如果父元素设值了,就用父元素的设定,如果父元素没设值,就用浏览器的缺省设定。直接看图最明白:
以上就是在css
里display
的32
种写法。谈了这么多,不知道你记住了多少呢?其实,单纯理解每一个display
属性的取值都不难,难的是融会贯通,在恰当的地方运用恰当的值,毕竟我们的目的是为了把代码写短,而不是把代码写长。
最近更新时间:2024-08-10