“流”又叫文档流,是css的一种基本定位和布局机制。流是html的一种抽象概念,暗喻这种排列布局方式好像水流一样自然自动。“流体布局”是html默认的布局机制,如你写的html不用css,默认自上而下(块级元素如div)从左到右(内联元素如span)堆砌的布局方式。
块级元素是指单独撑满一行的元素,如div、ul、li、table、p、h1等元素。这些元素的display值默认是block、table、list-item等。
内联元素又叫行内元素,指只占据它对应标签的边框所包含的空间的元素,这些元素如果父元素宽度足够则并排在一行显示的,如span、a、em、i、img、td等。这些元素的display值默认是inline、inline-block、inline-table、table-cell等。
实际开发中,我们经常把display计算值为inline inline-block inline-table table-cell的元素叫做内联元素,而把display计算值为block的元素叫做块级元素。
width、height的默认值都是auto。
对于块级元素,width: auto的自动撑满一行。
对于内联元素,width: auto则呈现出包裹性,即由子元素的宽度决定。
无论内联元素还是块级元素,height: auto都是呈现包裹性,即高度由子级元素撑开。但是父元素设置height: auto会导致子元素height: 100%百分比失效。
流体布局之下,块级元素的宽度width: auto是默认撑满父级元素的。这里的撑满并不同于width: 100%的固定宽度,而是像水一样能够根据margin不同而自适应的宽度。
css的属性非常有意思,正常流下,如果块级元素的width是个固定值,margin是auto,则margin会撑满剩下的空间;如果margin是固定值,width是auto,则width会撑满剩下的空间。这就是流体布局的根本所在。
外在盒子
是决定元素排列方式的盒子,即决定盒子具有块级特性还是内联特性的盒子。外在盒子负责结构布局。
内在盒子
是决定元素内部一些属性是否生效的盒子。内在盒子负责内容显示。
如 display: inline-table
; 外在盒子就是inline
,内在盒子就是table
。
外在盒子决定了元素要像内联元素一样并排在一排显示,内在盒子则决定了元素可以设置宽高、垂直方向的margin等属性。如下图:
右侧的table和左侧的文字在一行排列(外在盒子inline的表现特征),同时有拥有自定义宽度110px(内在盒子table可以设置宽高)。
!important
css选择器权重列表如下:
在css中,!important的权重相当的高,但是由于宽高会被max-width/min-width覆盖,所以!important会失效。
width: 100px!important;
min-width: 200px;
上面代码计算之后会被引擎解析成:
width: 200px;
元素的内在盒子是由margin box
、border box
、padding box
、content box
组成的,这四个盒子由外到内构成了盒模型。
IE模型:box-sizing: border-box 此模式下,元素的宽度计算为border+padding+content的宽度总和。
w3c标准模型):box-sizing: content-box 此模式下,元素的宽度计算为content的宽度。
由于content-box在计算宽度的时候不包含border pading很烦人,而且又是默认值,业内一般采用以下代码重置样式:
:root {
box-sizing: border-box;
}
* {
box-sizing: inherit;
}
内联元素是指外在盒子默认是内联盒子的元素。从表现来说,内联元素的典型特征就是可以和文字在一行显示。因此文字也是内联元素。图片、按钮、输入框、下拉框等替换元素也是内联元素。内联盒模型是指内联元素包含的几个盒子,理解记忆下面的几个概念对css的深入学习极其重要。
替换元素是指内容可以替换的元素,实际上就是content box可以被替换的元素。如存在src=""属性的
元素和可以输入文本的
元素等。
所有替换元素都是内联元素,默认display属性是inline或inline-block(除了input[type="hidden"]
默认display: none;)。
替换元素有自己默认的样式、尺寸(根据浏览器不同而不同),而且其vertical-align
属性默认是bottom
(非替换元素默认值是baseline
)。
对于非替换元素如div,其content就是div内部的元素。
而对于替换元素,其content就是可替换部分的内容。
CSS中的content属性主要用伪元素:before/:after中,除了做字体库和少写个div,对于一般开发来说并无卵用。
padding是四大金刚中最稳定的了,少见有什么异常。尽管如此还是有些需要注意的地方:
1.大部分情况下我们会将元素重置为box-sizing: border-box
,宽高的计算是包含了padding
的,给人一种padding
也是content box
一部分的感觉,好像line-height
属性也作用于padding
上。但实际上,元素真正的内容的宽高只是content box
的宽高,而line-height
属性是不作用于padding
的。
2.padding
不可为负值,但是可以为百分比值。为百分比时水平和垂直方向的padding
都是相对于父级元素宽度计算的。将一个div设为padding: 100%
就能得到一个正方形,padding: 10% 50%
可以得到一个宽高比 5:1 的矩形。
body {
width: 400px;
}
.box {
padding: 10% 50%;
}
3.padding配合background-clip属性,可以制作一些特殊形状:
/*三道杠*/
.icon1 {
box-sizing: border-box;
display: inline-block;
width: 12px;
height: 10px;
padding: 2px 0;
border-top: 2px solid currentColor;
border-bottom: 2px solid currentColor;
background: currentColor; /*注意如果此处背景颜色属性用缩写的话,需要放到其他背景属性的前面,否则会覆盖前面的属性值(此处为background-clip)为默认值*/
background-clip: content-box;
}
/*双层圆点*/
.icon2 {
display: inline-block;
width: 12px;
height: 12px;
padding: 2px;
border: 2px solid currentColor;
border-radius: 50%;
background-color: currentColor;
background-clip: content-box;
}
预览如下:(currentColor是css中为数不多的变量,指当前文字的颜色值,非常好用)
作为外边距,margin属性并不会参与盒子宽度的计算,但通过设置margin为负值,却能改变元素水平方向的尺寸:
<div>asdfdiv>
<style>
div {
margin: 0 -100px;
}
style>
此时div元素的宽度是比父级元素的宽度大200px的。但是这种情况只会发生在元素是流布局的时候,即元素width是默认的auto并且可以撑满一行的时候。如果元素设定了宽度,或者元素设置了float: left / position: absolute
这样的属性改变了流体布局,那么margin为负也无法改变元素的宽度了。
块级元素的垂直方向会发生margin合并,存在以下三种场景:
margin
合并;margin-top
和子元素margin-top
,父元素margin-bottom
和子元素margin-bottom
;margin-top
和margin-botom
合并,例子如下:要阻止margin合并,可以:
margin的百分比值跟padding一样,垂直方向的margin和水平方向上的一样都是相对于父元素宽度计算的。
<div class="box">
<div>div>
div>
<style>
.box{
overflow: hidden;
background-color: lightblue;
}
.box > div{
margin: 50%;
}
style>
这里父元素设置overflow: hidden
是利用 bfc
的特性阻止子元素的margin
和父元素合并,换成其他bfc
特性或者设置 1px 的 border / padding
都是可以达到效果的。
margin: auto
能在块级元素设定宽高之后自动填充剩余宽高。margin: auto
自动填充触发的前提条件是元素在对应的水平或垂直方向具有自动填充特性,显然默认情况下块级元素的高度是不具备这个条件的。典型应用是块级元素水平局中的实现:
display: block;
width: 200px;
margin: 0 auto;
auto
的特性是,如果两侧都是auto
,则两侧均分剩余宽度;如果一侧margin
是固定的,另一侧是auto
,则这一侧auto
为剩余宽度。栗子:
除了水平方向,垂直方向的margin
也能实现垂直居中,但是需要元素在垂直方向具有自动填充特性,而这个特性可以利用position
实现:
position: absolute;
left: 0; right: 0; top: 0; bottom: 0;
width: 200px;
height: 200px;
margin: auto;
border主要作用是做边框。border-style属性的值有none/solid/dashed/dotted/double等,基本看名字就能猜出什么来了:
border-width
属性的默认值是3px
,是为了照顾小弟border-style: double
,你懂的。值得注意的是,border-color
默认是跟随字体的颜色,相当于默认设置了border-color: currentColor
一样。
border另一广受欢迎的功能就是图形构建,特别是做应用广泛的三角形,其原理可看下图的1-3:
div{
float: left;
margin: 20px;
}
div:nth-child(1){
width: 20px;
height: 20px;
border: 20px solid;
border-color: blue red orange green;
}
div:nth-child(2){
width: 20px;
height: 20px;
border: 20px solid;
border-color: blue transparent transparent transparent;
}
div:nth-child(3){
border: 20px solid;
border-color: blue transparent transparent transparent;
}
div:nth-child(4){
border-style: solid;
border-width: 40px 20px;
border-color: blue transparent transparent transparent;
}
div:nth-child(5){
border-style: solid;
border-width: 40px 20px;
border-color: blue red transparent transparent;
}
其实就是将其他三个边框的颜色设置透明,并把宽高设为 0 。图中4-5两个图形,是通过调整边框宽度和颜色调整三角形的形状,把最后一个图的红色改为蓝色,则是一个直角三角形了。
line-height
和vertical-align
line-height和vertical-align是控制元素垂直对齐的两大属性,也是最难理解搞懂的属性。
在内联元素的垂直方向对齐中,基线是最为重要的概念。line-height
定义的就是两基线之间的距离,vertical-align
的默认值就是基线。基线的定义则是字母 x 的下边缘。
css中有个概念叫x-height
,指的是小写字母 x 的高度。vertical-align: middle
对齐的就是基线往上1/2x-height
高度的地方,可以理解为近似字母 x 的交叉点。
css中除了px/em/rem
等,还有个单位是ex
。指的就是小写字母x的高度,即x-height
。用处不大,不再介绍。
normal
:默认值normal其实是类型为数值的变量,根据浏览器和字体’font-family’不同而不同,一般约为 1.2 。
数值和百分比:最终会被计算为带单位的值,具体计算方法就是乘以字体大小font-size。
长度值:就是100px这样带单位的值。
这几类值的继承特性不同:line-height是数值的元素的子元素继承的就是这个数值,百分比/长度值继承的都是计算后得出的带单位的值(px)
line-height属性用于设置多行元素的空间量,如多行文本的间距。
对块级元素来说,line-height
决定了行框盒子的最小高度。注意是行框盒子的最小高度,而不是块级元素的实际高度。(图中两个div行高一样,div.one 的背景色区域就是行框盒子的高度,而 div.two 的背景区域则是实际高度,其行框盒子高度和 div.one 是一样的。)
对于非替代的 inline 元素,它用于计算行框盒子的高度。此时内联元素的行框盒子的高度完全由line-height决定,不受其他任何属性的影响
行距是指一行文本和相邻文本之间的距离。行距 = line-height
— font-size
。行距具有上下等分的机制:意思就是文字上下的行距是一样的,各占一半,这也是line-height能让内联元素垂直居中的原因。下图中字母x上下行距各占一半,共同撑起了div。
下图中和上图唯一不同之处就是多了个display: inline-block
的span元素,但是此处的span元素并没有影响div元素的高度,而只是靠着vertical-align: middle属性将自身中心点对齐了字母x的交叉点实现垂直居中而已。div元素的高度仍然和上图一模一样,由字母x和行距共同撑起。此时如果删除字母x,div的高度不变,因为span元素的行框盒子前会产生幽灵空白节点,而幽灵空白节点+行高也能撑起div。
<div class="box">
<span>asdfspan>
div>
样式1:此时 .box 高度是多少?
.box {
line-height: 100px;
background: lightgreen;
}
.box span {
line-height: 30px;
}
样式2:此时 .box 高度是多少?
.box {
line-height: 30px;
background: lightgreen;
}
.box span {
line-height: 100px;
}
先说结论:无论内联元素的line-height如何设置,最终父元素的高度都是数值大的那个line-height决定的。
样式1中,span元素的行框盒子前存在一个幽灵空白节点,而这个幽灵空白节点的行高是100px;样式2中,幽灵空白节点的行高是30px,但是这时span元素的行高是100px。两种情况其实一样,取大值而已。
线类:如baseline(默认值)
top
middle
bottom
(baseline使元素的基线与父元素的基线对齐,middle使元素的中部与父元素的基线往上x-height的一半对齐。top bottom使元素及其后代元素的底部与整行或整块的底部对齐。)
文本类:text-top
text-bottom
(使元素的顶部与父元素的字体顶部对齐。)
上标下标:sub
super
(使元素的基线与父元素的下标基线对齐。)
数值:20px
2em
(默认值baseline相当于数值的 0 。使元素的基线对齐到父元素的基线之上的给定长度,数值正值是基线往上偏移,负值是往下偏移,借此可以实现元素垂直方向精确对齐。)
百分比:20%
(使元素的基线对齐到父元素的基线之上的给定百分比,该百分比是line-height属性的百分比。)
vertical-align属性起作用的前提必须是作用在内联元素上。 即display计算值为inline inline-block inline-table table-cell的元素。所以如果元素设置了float: left或者position: absolute,则其vertical-align属性不能生效,因为此时元素的display计算值为block了。
有时候会遇见下面这样高度和设置不一致的情况:
内联元素的默认对齐方式是baseline,所以此时此时span元素的基线是和父元素的基线相对齐的,而此时父元素的基线在拿呢?
父元素的基线其实就是行框盒子前的幽灵空白节点的基线。把幽灵空白节点具象化为字母x可能容易理解些:
由于div行高是30px,所以字母x和span元素的高度都是30px。但是字母x的font-size较小,span元素的font-size较大,而行高一样的情况下font-size越大基线的位置越偏下,所以两者的基线不在同一水平线上。如下图左边部分:
由于内联元素默认基线对齐,所以字母x和span元素发生了位移以使基线对齐,导致div高度变大。而此时字母x的半行距比span元素的半行距大,大出的部分就是div的高度增加的部分。
display: inline-block
基线的不同之处先看例子,图中span元素设置了display: inline-block
和宽高,从而撑起了父元素div
的高度,但span本身并无margin属性,那为什么底部和div下边缘之间会有空隙呢?
这就要说到inline-block
的不同之处了。一个设置了display: inline-block的元素:
知道了这点,那么再回到上面的例子:
原来是第三者幽灵空白节点搞的鬼。此时span的行框盒子前,还存在一个幽灵空白节点。由于span元素默认基线对齐,所以span元素的基线也就是其下边缘是和幽灵空白节点的基线对齐的。从而导致幽灵空白节点基线下面的半行距撑高了div元素,造成空隙。如下图:
如果span
元素中存在内联元素呢?
可以看到,此时span元素下边缘的空隙没了,因为此时span元素的基线是内部最后一行内联元素的基线。
值得一提的是,由于替换元素内部不可能再有别的元素,所以其基线位置永远位于下边缘。
间隙产生本质上是由基线对齐引发的错位造成的,源头上是vertical-align和line-height共同造成的,所以要想解决这个问题,只要直接或间接改造两个属性中的一个就行了:
下面是张鑫旭大佬推荐的利用vertical-align实现的水平垂直居中弹框,能够理解的话就说明你已经完全掌握了好基友和第三者的关系了。
<div class="container">
<div class="dialog">自适应弹出层div>
div>
<style>
.container{
position: fixed;
top: 0; right: 0; bottom: 0; left: 0;
background-color: rgba(0, 0, 0, .15);
text-align: center;
font-size: 0;
white-space: nowrap;
overflow: auto;
}
.container:after{
content: '';
display: inline-block;
height: 100%;
vertical-align: middle;
}
.dialog{
display: inline-block;
width: 400px;
height: 400px;
vertical-align: middle;
text-align: left;
font-size: 14px;
white-space: normal;
background: white;
}
style>
现在UI框架横行的年代,我们的css写的越来越少了。这对于很多老鸟来说是件好事,但是对于初入前端的小白却未必。因为写的少了,就少了很多练手和总结的机会,对于很多样式理解就不透彻。本章介绍的float、position 和BFC对于前端页面布局非常重要,希望诸位看官们静下心来仔细研读。
float
属性的特性float属性应该是css世界最令人意外的属性了,倒不是因为他的表现,而是他的设计初衷竟然只是为了实现“文字环绕图片”的效果。只不过因为float属性的一些特性,才导致其被到处使用以致于产生了诸多不利于维护的页面。
下面看看float属性的特性:
前三个特性都是正能量满满,但是最后一个特性却给我们开发者带来了很多麻烦,需要用到clear来清除浮动。
clear
的作用和不足大家都知道clear: both可以清除前面浮动元素的浮动,但实际上,他并不是真的清除了浮动。
clear的定义是:元素盒子的边不能与前面的浮动元素相邻。也就是虽然浮动元素高度坍塌,但是设置了clear: both的元素却将其高度视为仍然占据位置。
clear只能作用于块级元素,并且其并不能解决后面元素可能发生的文字环绕问题。
BFC
是一个独立的渲染区域,只有Block-level box
参与, 它规定了内部的Block-level Box
如何布局,并且与这个区域外部毫不相干。
BFC 就好像一个结界,结界里面的东西不能影响外面的布局,也就是说,BFC的子元素再翻江倒海,都不会影响外面的元素。 所以:
BFC的创建方法
BFC包含创建该上下文元素的所有子元素,但不包括创建了新BFC的子元素的内部元素。
特性 1 中内部的盒是指块级盒。因为根元素也是BFC,所以我们平常写的div p都是独自占一行。
特性 2是BFC,所以里面的元素垂直方向的margin会发生折叠。但是,直接子孙元素与该BFC上下边界margin不能折叠,保证了BFC内部的元素不会影响外部的元素。两个上下相邻的BFC之间折不折叠要看具体情况,如
display: inline-block
float: left
不会折叠,而overflow: hidden
则会折叠。
特性 3 完全解读:
每一个盒子的左外边距应该和包含块的左边缘相接触
第一,包含块未必就是父级元素。对于position: absolute来说,包含块是指第一个positoin不为static的祖先元素。
第二,BFC中的盒子应该与其自身的包含块相接触,而非与BFC盒子本身相接触。
第三,BFC中的盒子是与其包含块的left edge
相接触,而不是包含块的 left-border
相接触。left edge 正确的翻译为左边缘。左边缘可能是content box的左边缘(非绝对定位如position: absolute),也可能是padding box的左边缘(如position: absolute)。
理解了上面两点,其实特性 3 就是普通的流布局和定位布局默认贴着“左侧”思想的总结。
如图,aside元素的margin box的左边距和BFC元素的左边缘相接触。并且由于float box高度坍塌,main占据了body全部空间并且和BFC盒子左边缘相接触(特性3“即使存在浮动也是如此”)。
特性 4 正是BFC存在的意义。它规定了BFC子元素无论margin-top: -10000px float: left 等都不会影响到BFC外部的元素的布局。所以BFC是最好的清除浮动的方式,连浮动的文字环绕问题都能解决。
特性 5 BFC计算高度时包含浮动元素的高度。可以利用BFC此特性解决浮动元素高度坍塌的问题。
特性 6 :利用特性6实现自适应两栏布局。此时main宽度是自适应的。
position: absolute
和浮动元素一样,绝对定位也具有块状化、BFC、包裹性、脱离文档流、没有margin合并的特性。
但和浮动不同的是,绝对定位是完全的脱离文档流。大家还记得浮动产生的目的就是为了实现文字环绕效果,所以浮动元素虽然脱离了文档流,但是后面的文字还是会环绕在浮动元素周围。而绝对定位一但产生,就不会再对周围元素产生任何影响。
而且两者包含块不同,浮动元素包含块只能是父级元素,绝对定位的包含块则是距离最近的position不为static的祖先元素。
大多数用到绝对定位的时候,都是存在包含块和left/top
等方向属性的。但其实position: absolute
是非常独立的css属性,其样式和行为表现不依赖任何css属性就可以完成。
可以看出,无依赖的position: absolute
元素定位的位置和其本身无定位属性时候的位置和display的值有关。如果元素在没有position
的情况下是内联元素,则和内联元素在同一行显示;如果元素在没有position
属性的情况下是块级元素,则换行显示。
无依赖绝对定位的实用性虽然还行,但是其功能却完全可以用left/top实现。所以了解即可,如果有兴趣可以自行尝试。
overflow: hidden
其实一句话就可以表示两者之间的关系:当overflow: hidden
元素在绝对定位元素和其包含块之间的时候,绝对定位元素不会被剪裁。
以下两种绝对定位元素不会被剪裁:
<div style="overflow: hidden;">
<img src="big.jpg" style="position: absolute;">
div>
<div style="position: relative;">
<div style="overflow: hidden;">
<img src="big.jpg" style="position: absolute;">
div>
div>
以下两种绝对定位元素会被剪裁:
<div style="overflow: hidden; position: relative;">
<img src="big.jpg" style="position: absolute;">
div>
<div style="overflow: hidden;">
<div style="position: relative;">
<img src="big.jpg" style="position: absolute;">
div>
div>
position: absolute的流体特性
当绝对定位元素的水平方向(left/right)或垂直方向(top/bottom)的两个定位属性同时存在的时候,绝对元素在该方向上便具有了流体特性。此时的width/height属性具有自动撑满的特性,和一个正常流的div元素的width属性别无二致。如图,设置了固定margin值的元素,宽高auto能够自动适应剩余空间:
同样的,设置了固定宽高的元素,如果margin: auto,则margin平分剩余空间导致垂直水平居中:
层叠规则是指当网页中的元素发生层叠时侯的遵循的规则。
层叠上下文好像是一个结界,层叠上下文内的元素如果跟层叠上下文外的元素发生层叠,则比较该层叠上下文和外部元素的层叠上下文的层叠水平高低。
创建一个层叠上下文的方法就是给position
值为relative/aboslute/fixed
的元素设置z-index
不为auto
的值。
最底层的border/background是指当前层叠上下文元素的边框和背景色。z-index为负值的元素在其之上。
如下图所示.dad
元素默认设置z-index: auto
,没有创建层叠上下文,此时其就是一个普通的块级盒子,所以设置了z-index: -1
的.son
元素跑到了爸爸身后看不见了。
而由于.mom
设置了z-index: 0
,创建出了一个层叠上下文,所以.son
元素就算设置了z-index: -1
也跑不出老妈的视线。
当块级元素和内联元素发生层叠,内联元素居于块级元素之上。如下图
普通定位元素层叠水平在普通元素之上。普通定位元素是指z-index为auto的定位元素。下图span就是普通定位元素:
CSS3带来了很多新属性,其中很不惹人注意的一点就是增加了很多会自动创建层叠上下文的属性:
这些属性大都不支持z-index,所以他们都默认z-index: auto,跟普通定位元素层叠水平一样,所以如果发生层叠会后来居上:
但是弹性盒子display: flex不同,弹性盒子的子元素支持设置z-index,且设置了数值的z-index也会自动创建层叠上下文。如下图,可以看到设置了z-index: 0的元素层叠水平更高。
弹性布局是指display: flex
或display: inline-flex
的布局。注意,设为弹性布局以后,子元素的float
、clear
、vertical-align
属性都会失效。参见阮一峰大佬的 Flex 布局教程。
网格布局(Grid)是最强大的 CSS 布局方案。注意,设为网格布局以后,容器子元素(项目)的float
、display: inline-block
、display: table-cell
、vertical-align
和column-*
等设置都将失效。参见阮一峰大佬的CSS Grid 网格布局教程。
::first-letter
选中首个字符:
text-transform
应用假设有个输入框只能输入大写字母,那么如下设置,输入小写字母出现的却是大写字母,可用于身份证输入框或验证码输入框等:
input {
text-transform: uppercase;
}
word-spacing
空格间隙不要被表面意思误导,word-spacing
指的是字符“空格”的间隙。如果一段文字中没有空格,则该属性无效。下面代码设定空格间隙是20px,也就是说空格现在占据的宽度是原有的空格宽度+20px的宽度:
<p>我有空 格,我该死......p>
<style>
p {
word-spacing: 20px;
}
style>
white-space
空白处理我们都知道如果在html中输入多个空白符,默认会被当成一个空白符处理,实际上就是这个属性控制的:
text-align: justify
(本文重点例子!)text-align: justify
为两端对齐。除了实现文字的两端对齐,还能用来做一些两端对齐的布局。(注意下面例子自己测试时需要保证每行三个方块!!!)下面介绍个两端对齐布局的实例:
由于text-align: justify
最后一行是左对齐,所以利用了三个空的i标签模拟最后一行。虽然实现了两端对齐,但是最后一行却出现间隙。根据之前的经验应该是vertical-align和line-height搞的鬼,我们给i标签加上outline并用字母 x 模拟幽灵空白节点,
上图分析:首先第一个i标签基线与第二行的span标签中的数字的基线对其,所以其位置在中间。其次最后一行的i标签基线对齐幽灵空白节点字母x的基线,没有错位,所以此时最后一行的间隙高度就是字母x的高度。所以很容易想到把幽灵空白节点的行高设为 0 来解决问题:
然而间隙虽然缩小了,但是还是存在。此时由于行高为 0 ,幽灵空白节点也就是字母x在页面中占用的真实位置其实是红线所示。也就是说虽然字母 x 还显示在页面上,但是其真实高度已经为0,此时其中线、上边缘线、下边缘线合一,都在红线位置,其真实位置自然也就在红线位置。然而其基线却不会改变,在字母 x 下边缘。
此时i标签的基线发生错位,位移到下面与幽灵空白节点基线对齐,导致产生了间隙。
所以只需要再改变i标签的对齐方式,就能彻底清除间隙:
如果改为vertical-align: top是一样的,因为合一了。但是vertical-align: middle却不行,因为此middle的位置是基线往上 1/2 个e-height的地方。
好吧本例结束了,没想到解释起来这么复杂。好好理解此例加深对vertical-align和line-height的理解。
元素的显示隐藏方法很多,不同方法的在不同的场景下页面效果不一,对页面的性能也有不同的影响。
元素隐藏方法总结:
div{
position: absolute;
visibility: hidden;
opacity: 0;
transition: opacity .5s linear;
background: cyan;
}
div.active{
visibility: visible;
opacity: 1;
}
这里使用visibility: hidden而不是display: none,是因为display: none会影响css3的transition过渡效果。
但是display: none并不会影响cssanimation动画的效果。
display: none
与visibility: hidden
的区别本篇文章来源是前端技术优选公众号 ,仅在此作为笔记使用。