html面经——css

1、介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同?

盒模型都是由四个部分组成的,分别是margin、border、padding和content

标准盒模型和IE盒模型的区别在于设置width和height时,所对应的范围不同。标准盒模型的width和height属性的范围只包含了content,而IE盒模型的width和height属性的范围包含了border、padding和content。

一般来说,我们可以通过修改元素的box-sizing属性来改变元素的盒模型。

2、CSS的选择器有哪些?

  1. id选择器(#myid)
  2. 类选择器(.myclassname)
  3. 标签选择器(div ,h1,p)
  4. 后代选择器(h1 p)
  5. 子选择器(ul>li)
  6. 兄弟选择器(所有)(li~a)
  7. 相邻兄弟选择器(li+a )
  8. 属性选择器(a[rel=“external”])
  9. 伪类选择器(a:hover,li:nth-child)
  10. 伪元素选择器(::before ::after)
  11. 通配符选择器(*)

3、::before和::after中双冒号和单冒号有什么区别?解释一下这两个伪元素的作用。

在css3中使用单冒号来表示伪类,用双冒号来表示为元素。但是为了兼容已有的伪元素的用法,在一些浏览器中也可以使用单冒号来表示伪元素。
伪类一般匹配的是元素的一些特殊状态,比如hover、link等。而伪元素一般匹配的特殊的位置,比如after、before等。

4、伪类与伪元素的区别

css引入伪类和伪元素概念是为了格式化文档树以外的信息。也就是说,伪类和伪元素是用来修饰不再在文档树中的部分,比如,一句话中的第一个字母或者是列表中的第一个元素。

伪类用于当已有的元素处于某个状态的时候,为其添加对应的样式,这个状态是根据用户行为而动态变化的。比如说,当用户悬停在指定的元素的时候,我们可以通过:hover来描述这个元素的状态。

伪元素用于创建一些不在文档树中的元素,并为其添加样式。它们允许我们为 元素的某些部分设置样式。比如说,我们可以通过::before 来在一个元素前面添加一些文本,并为这些文本设置样式。虽然用户可以看到这些文本,但是这些文本实际不存在于文档树中。

有时你会发现伪元素使用了两个冒号(::)而不是一个冒号。这是css3的一部分,并尝试区分伪类和伪元素。大多数浏览器都支持这两个值。按照规则应该使用双冒号而不是单冒号。从而区分是伪元素还是伪类。但是,由于在旧的W3C龟板并未对此进行特别区分,因此目前绝大多数的浏览器都支持这两种方式表示伪元素。

5、CSS中哪些属性可以被继承?

每一个属性在定义中都给出了这个属性是否具有继承性,一个具有继承性的属性会在没有指定值的时候,会使用父元素的同属性的值来作为自己的值。

一般来说具有继承性的属性有
字体相关的属性:font-size和font-weight等。
文本相关的属性:color和text-align等。
表格的一些属性、列表的一些属性如list-style等。
还有光标属性cursor、元素可见性visibility。

当一个属性不是继承属性的时候,我们也可以通过将它的值设置为inherit来使它从父元素那获取同名的属性值来继承。

6、CSS优先级的计算

判断优先级的时候,首先我们会判断一条属性声明是否具有权重,也就是是否在声明的后面加上了!important。一条声明如果加上了权重,那么它的优先级是最高的,前提是它之后不再出现相同权重的声明。如果权重相同,我们则需去比较匹配规则的特殊性。

一条匹配规则一般由多个选择器组成,一条规则的特殊性由组成它的选择器的特殊性累加而成。选择器的特殊性可以分成四个等级

  1. 行内样式,1000
  2. id选择器 0100
  3. 类选择器、伪类选择器和属性选择器 0010
  4. 元素选择器和伪元素选择器 0001
    规则中每出现一个选择器,就将它的特殊性进行叠加,这个叠加只限于对应的等级的叠加,不会产生进位。选择器特殊性值的比较是从左向右排序的,也就是说1开头的特殊性值比所有以0开头的特殊性值要大。

如果两个规则的特殊值相等的时候,那么就会根据它们引入的顺序,后出现的规则的优先级越高。

7、对于LVHA的解释?

a标签有四种状态:连接访问前,链接访问后、鼠标滑过、激活状态,分别对应四种伪类::link、:visited、:hover、:active

当链接未访问时:

  1. 当鼠标滑过a链接时,满足:link和:hover两种状态,要改变a标签 的颜色,就必须将:hover放在:link的后面声明
  2. 当鼠标点击激活a链接的时候,同时满足:link、:hover、:active三种状态,要显示a标签激活时的样式(:active)就必须把它放到link和hover之后。所以得出LVHA这个顺序。
    当链接访问过时候,情况基本同上,只不过需要将:link换成:visited

这个顺序可以变,但是只有link和visited能够交换位置,因为一个链接要么访问过要么没访问过,不可能同时满足。也就不存在覆盖的问题。

8、CSS新增的伪类有哪些?

  1. :enabled:控制表单控件的状态
  2. :disabled:控制表单控件的状态
  3. :checked单选框或复选框被选中
  4. elem:empty选中不包含子元素和内容的elem类型元素

9、如何居中div?

一般常见的几种居中方法有:
对于宽高固定的元素

  1. 利用margin:0 auto来实现元素的水平居中
  2. 利用绝对定位,设置四个方向的值都为0,并将margin设置为auto,由于宽高固定,因此对应方向实现平分,可以实现水平和垂直方向上的居中。
  3. 利用绝对定位,先将元素的左上角通过left:50%和top:50%定位到页面的中心,然后再通过margin负值来调整元素的中心点到页面的中心
  4. 利用绝对定位,先将元素的左上角通过top:50%和left:50%定位到页面的中心,然后再通过translate来调整元素的中心点到页面的中心。
  5. 使用flex布局,通过align-items:center和justify-content:center设置容器的垂直和水平方向上的居中对齐,然后它的子元素也可以实现垂直和水平居中。

对于宽高不固定的元素,上面的后两种方法,可以实现元素的垂直和水平居中。

10、display有哪些值?说明它们的作用?

  1. block 块类型。默认宽度为父元素宽度,可设置宽高,换行显示。
  2. none 元素不显示,并从文档流中移除
  3. inline 行内元素类型。默认宽度为内容宽度,不支持设置宽高,同行显示。
  4. inline-block 默认宽度为内容宽度,可以设置宽高,同行显示。
  5. list-item 像块类型元素一样显示,并添加样式列表标记。
  6. table 此元素会作为块级表格来显示。
  7. inherit 规定应该从父级元素继承display属性 的值。

11、position的值relative和absoulute定位原点是?

relative定位的元素,是相对于元素本身所在文档流中的位置进行定位的。
absolute定位的元素,是相对于它的第一个position值不为static的祖先元素的padding box来进行定位的。这句话我们可以这样来理解,首先需要找到一个绝对定位元素的一个position的值不为static的祖先元素,然后相对于这个祖先元素的padding box来进行定位,也就是说在计算定位距离的时候,padding的值也要算进去。

12、CSS有哪些新特性?(根据项目回答)

新增各种CSS选择器(:not(.input):所有class不是“input”的节点)
圆角border-radius
多列布局 multi-column layout
阴影和反射 shadow\reflect
文字特效 text-shadow
文本修饰 text-decoration
线性渐变 linear-gradient
旋转 transform:rotate
缩放,平移,倾斜,动画,多背景

13、请解释一下css3的Flex box(弹性盒布局模型),以及适用场景?

flex布局是css3新增的一种布局方式,我们可以通过将一个元素的display属性值设置为flex从而使它成为一个flex容器,它的所有子元素都会成为它的弹性元素。

一个容器默认有两条轴,一个是水平的主轴,一个是与主轴垂直的辅轴。我们可以使用flex-direction来指定主轴的方向。
我们可以使用justify-content来指定元素在主轴上 的排列方式,使用align-items来指定元素在辅轴上的排列方式。还可以使用flex-wrap来规定当一行排列不下时的换行方式。
对于容器中的弹性元素,我们可以使用order属性来指定元素的排列顺序。还可以使用flex-grow来指定当排列空间有剩余的适合,元素的增长系数。还可以使用flex-shrink来指定当排列空间不足时,元素的缩减系数。

14、用纯CSS创建一个三角形的原理是什么?

采用的是相邻边框连接处的均分原理。
将元素的宽高设置为0,只设置border,把任意三条边隐藏掉(颜色设置为transparent),剩下的就是一个三角形。

#demo{
width:0;
height:0;
border-width:20px;
border-style:solid;
border-color:transparent transparent red transparent;
border-top:none;//加上这一行可以让三角形顶个,不加三角形会下移20px
}

15、一个满屏品字布局如何设计?

简单的方式:
上面的div宽100%
下面的两个div分别宽50%
然后用float或者inline使其不换行即可

16、CSS多列等高如何实现?

  1. 利用padding-bottom|margin-bottom正负值相抵,不会影响页面布局的特点。设置父容器超出隐藏(overflow:hidden),这样父容器的高度就还是它里面的列没有设定padding-bottom时的高度,当它里面的任一列高度增加了,则父容器的高度被撑到里面最高那列的高度,其他比这列矮的列会用他们的padding-bottom补偿这部分高度差
  2. 利用table-cell所有单元格高度都相等的特性,来实现多列等高。
  3. 利用flex布局中弹性元素align-items属性默认为stretch,如果弹性元素未设置高度或者设为auto,将占满整个容器的高度的特性,来实现多列等高。

17、经常遇到的浏览器的兼容性有哪些?原因,解决方法是什么,常用hack的技巧?

  1. ong24位的图片在IE6浏览器上出现背景。解决方案:做成PNG8,也可以引用一段脚本处理。
  2. 浏览器默认的margin和padding不同。解决方案:加一个全局的*{margin:0;padding:0;}来统一。
  3. IE6双边距bug:在IE6下,如果堆元素设置了浮动,同时又设置了margin-left或者margin-right,margin值会加倍。#box{float:left;width:10px;margin:0 0 0 10px} 。这种情况之下IE会产生20px的距离。解决方案:在float的标签样式控制中加入_display:inline;将其转化为行内属性。(_这个符号只有ie6会识别)
  4. 渐进识别的方式,从总体逐渐排除局部。首先,巧妙地使用"\9"这一标记,将IE浏览器从所有情况中分离出来。接着,再次使用"+"将IE7\IE6分离开来,这样IE8已经独立识别。.bb{background-color:#flee18;//所有识别 background-color:#00deff\9//IE6、7、8识别 +background-color:#a200ff;//IE6、7识别 _background-color:#1e0bd1;//IE6识别}
  5. IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性。Firefox下,只能使用getAttribute()获取自定义属性。解决方法:统一通过getAttribute()获取自定义属性。
  6. IE下,event对象有x、y属性,但是没有pageX、pageY属性;Firefox下,event对象有pageX,pageY属性,但是没有x、y属性。解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。
  7. Chrome中文界面下默认会将小于12px的文本强制按照12px显示。解决方法:可以通过加入css属性-webkit-text-size-adjust:none解决,但是在chrome更新到27版本之后就不可以用了;还可以使用-webkit-transform:scale(0.5);注意-webkit-transform:scale(0.75);收缩的是整个span的大小,这时候,必须要将span转换成块元素,可以使用display:block/inline-block/…;
  8. 超链接访问过后hover样式就不出现了,被点击访问过的超链接样式不再具有hover和active了。解决方法:改变css属性的排列顺序 L-V-H-A
  9. 怪异模式问题:漏写DTD声明,firefox仍然会按照标准模式来解析网页,但在IE中会触发怪异模式。为了避免怪异模式给我们带来不必要的麻烦,最好养成写DTD声明的好习惯。

18、li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?

浏览器会把inline元素间空白字符(空格、换行、Tab等)渲染称一个空格。而为了美观,我们通常是一个< li > 方在一行,这导致< li >换行后产生换行字符,它变成一个空格,占用了一个字符的宽度。
解决办法:

  1. 为li设置float:left。不足:有些容器是不能设置浮动,比如左右切换的焦点图等。
  2. 将所有< li >写在同一行。不足:代码不美观
  3. 将< ul >内的字符尺寸直接设置为0,font-size:0。不足:< url >中的其他字符尺寸也被设为0,需要额外重新设定其他字符尺寸,而且在Safari浏览器依然会出现空白间隔。
  4. 消除< ul >的字符间隔letter-spacing:-8px,不足:这样也设置了< li >内的字符间隔,因此需要将< li >内的字符间隔设为默认letter-spacing:normal

19、为什么要初始化CSS样式?

因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对CSS初始化往往会出现浏览器之间的页面显示差异。
当然,初始化样式会对SEO有一定的 影响,但力求影响最小的情况下初始化。

最简单的初始化方法:*{padding:0;margin:0;}
(强烈不建议)

20、什么是包含块,对于包含块的理解?

默认情况下包含块就是距离当前元素最近的块级祖先元素;对于开启了绝对定位的元素来说,包含块是离他最近的开启了定位(且position不为static)的祖先元素,如果所有的祖先元素都没有开启定位,则其包含块就是初始包含块。

21、CSS里的visibility属性有个collapse属性值是干嘛用的?在不同的浏览器有什么区别?

  1. 对于一般的元素,它的表现跟visibility:hidden;是一样的。元素是不可见的,但此时仍然占用页面空间。
  2. 但例外的是,如果这个元素是table相关的元素,例如table行,table、group、table列,table column group,它的表现却跟display:none一样,也就是说,它们占用的空间也会释放。
  3. 在不同浏览器下的区别:在谷歌浏览器里面,使用collapse值和使用hidden值没有什么区别。在火狐浏览器、opera和IE11里面,使用collapse值的效果就如它的字面意思,table的行会消失,它的下面一行会补充它的位置。

22、width:auto和width:100%的区别

一般而言,width:100%会使元素box的宽度等于父元素的content box的宽度。
width:auto会使元素撑满整个父元素,margin、border、padding、content区域会自动分配水平空间。

23、绝对定位元素与非绝对定位元素的百分比计算的区别

绝对定位元素的宽高百分比是相对于临近的position不为static的祖先元素的padding box来计算的。

非绝对定位元素的宽高百分比则是相对于父元素的content box计算的。

24、简单介绍使用图片base64编码的优点和缺点。

base64编码是一种图片处理格式,通过特定的算法将图片编码成一长串字符串,在页面上显示的适合,可以用该字符串来代替图片的url属性。

使用base64的优点是:

减少一个图片的HTTP请求
使用base64的缺点是:

  1. 根据base64的编码原理,编码后的大小回避源文件大小大1/3,如果把大图片编码到html/css中,不仅会造成文件体积的增加,影响文件的加载速度们还会增加浏览器对html或者css文件解析渲染的时间。
  2. 使用base64无法直接缓存,要缓存只能缓存包含base64的文件,比如html或者css,这相比于直接缓存图片的效果要差很多。
  3. 兼容性问题:ie8以前的浏览器不支持。

一般一些网站的小图标可以使用base64图片引入。

25、‘display’、'position’和’float’的相互关系?

  1. 首先我们判断display属性是否为none,如果为none,则position和float属性的值不影响元素最好的表现。
  2. 然后判断position的值是否为absolute或者fixed,如果是,则float失效,并且display的值应该被设置为table或者block,具体转换需要看初始转换值。
  3. 如果position的值不为absolute或者fixed,则判断float的属性是否为none,如果不是,则display的值则按上面的规则转换。注意,如果position的值为relative并且float属性的值存在,则relative相对于浮动后的最终位置定位。
  4. 如果float的值为none,则判断元素是否为根元素,如果是根元素则display属性按照上面的规则转换,如果不是,则保持指定的 display属性值不变。

总的来说,可以把它看成是一个类似优先级的机制,"position:absolute"和"position:fixed"优先级最高,有它存在的时候,浮动元素不起作用,'display’的值也需要调整;其次,元素的’float’特性的值不是’none’的时候或者它是根元素的时候,调整’display’的值;最后,非根元素,并且非浮动元素,并且非绝对定位的元素,'display’特性值同设置值。

26、margin重叠问题的理解

margin重叠指的是在垂直方向上,两个相邻元素的margin发生重叠的情况。

一般来说可以分为四种情形:
第一种是相邻兄弟元素的margin-bottom和margin-top的值发生重叠。这种情况下我们可以通过设置其中一个元素为BFC来解决。

第二种是父元素的margin-top和子元素的margin-top发生重叠。它们发生重叠是因为他们是相邻的,所以我们可以通过这一点来解决问题。我们可以设置父元素的border-top、padding-top值来分割它们,当然我们也可以将父元素设置为BFC来解决。

第三种是高度为auto的父元素的margin-bottom和子元素的margin-bottom发生重叠。它们发生重叠一个是因为它们相邻,一个是因为父元素的高度不固定。因此我们可以为父元素设置boder-bottom、padding-bottom来分隔他们。也可以为父元素设置一个高度,max-height和min-height也能解决这个问题。当然将父元素设置为BFC是最简单 的方法

第四种情况,是没有内容的元素,自身的margin-top和margin-bottom发生的重叠,我们可以通过为其设置border、padding或者高度来解决问题。

27、对BFC规范(块级格式化上下文:block formatting context)的理解?

BFC指的是块级格式化上下文。一个元素开启了BFC之后,那么它内部元素产生的布局不会影响到外部元素,外部元素的布局也不会影响到BFC中的内部元素。一个BFC就像是一个隔离区域,和其他区域互不影响。

一般来说根元素就是一个BFC区域,浮动和绝对定位的元素也会形成BFC,display属性的值为inline-block、flex这些属性的时候也会创建BFC。还有就是元素的overflow的值不为visible时都会创建BFC。

28、IFC是什么?

IFC指的是行级格式化上下文,它有这样的一些布局规则:

  1. 行级上下文内部的盒子会在水平方向,一个接一个地放置。
  2. 当一行不够时候会自动切换到下一行。
  3. 行级上下文的高度由内部最高的内联盒子的高度决定。

29、请解释一下为什么需要清除浮动?清除浮动的方式。

浮动元素可以左右移动,直到遇到另一个浮动元素或者遇到它外边缘的包含框。浮动框不属于文档流中的普通流,当元素浮动之后,不会影响块级元素的布局。只会影响内联元素布局。此时文档流中的普通流就会表现得该浮动框不存在一样的布局模式。当包含框的高度小于浮动框的时候,此时就会出现:高度塌陷/

清楚浮动是为了清楚使用浮动元素产生的影响。浮动的元素,高度会塌陷,而高度的塌陷使我们的页面后面的布局不能正常显示。

清除浮动的方式

  1. 使用clear属性清除浮动
  2. 使用BFC块级格式化上下文来清除浮动。
    因为BFC元素不会影响外部元素的特点,所以BFC元素也可以用来清楚浮动的影响,因为如果不清楚,子元素浮动则父元素高度塌陷,必然会影响后面元素布局和定位,这显然有违BFC元素的子元素不会影响外部元素的设定。

30、使用clear属性清除浮动的原理。

使用clear清除浮动,语法如下

clear:none|left|right|both

如果单看字面意思,clear:left应该是清楚左浮动,实际上,这种解释是有问题的。因为浮动一直还在,并没有清除。

官方对clear属性的解释是:元素盒子的边不能和前面的浮动元素相邻。我们对元素设置clear属性是为了避免浮动元素相邻对该元素的影响,而不是清楚浮动元素,

还要注意的一点是clear属性指的是元素盒子的边不能和前面的浮动元素相邻,注意这里前面的3个字,也就是clear属性对后面的浮动元素是不闻不问的,考虑到float属性要么是left,要么是right,不可能同时存在,同时由于clear属性对后面的浮动元素不闻不问,因此,当clear:left有效的时候,clear:right必定无效。也就是此时clear:left等效于设置clear:both;clear:right也如此。由此可见,我们可以直接使用clear:both

一般使用伪元素的方式清除浮动
.clear::before,
.clear::after{
content:‘’;
display:table;//也可以是block或者list-item
clear:both
}

clear属性只有块级元素才有效,而::after等伪元素默认都是内联水平,这就是借助伪元素清除浮动影响时需要设置display属性值的原因。

13、zoom:1的清除浮动原理?

清除浮动,处罚法hasLayout:
zoom属性是IE浏览器的专有属性,它可以设置或检索对象的缩放比例。解决ie下比较奇葩的bug。譬如外边距(margin)的重叠,浮动清除,触发ie的hashlayout等属性等。

来龙去脉大概如下:
当设置了zoom的值后,所设置的元素就会扩大或者缩小,高度宽度就会重新计算了,这一旦改变zoom值时其实也会发生重新渲染,运用这个原理,也就解决了ie子元素浮动时候会员数不随着自动扩大的问题。

zoom属性是IE浏览器的专有属性,火狐和老版本的webkit核心的浏览器都不支持这个属性。然后zoom现在已经被逐步标准化,出现在css3.0规范草案中。

目前非ie由于不支持这个属性,它们又是通过什么属性来实现元素的缩放呢?可以通过css3里面的动画属性scale进行缩放。

32、移动端的布局用过媒体查询吗?

假设你现在正在用一台显示设备来阅读这篇文章,同时你也想把他投影到屏幕上,或者打印出来,而显示设备、屏幕投影和打印等这些媒介都有自己的特点,css就是为文档提供在不同媒介上展示的适配方法。

当媒体查询为真的时候,相关的样式表或者样式规则会按照正常的级联规则被应用,当媒体查询返回假,标签上带有媒体查询的 样式表仍将被下载(只不过不会被应用)。

包含了一个媒体类型和至少一个使用宽度、高度和颜色等媒体属性来限制样式表范围的表达式。css3加入的媒体查询使得无需修改内容便可以使样式应用于某些特定的设备范围。

33、使用css预处理器吗?喜欢哪个?

sass(sass、less没有本质区别)

34、css优化、提升性能的方法有哪些?

加载性能:

(1)css压缩:将写好的css进行打包压缩,可以减少很多的体积。
(2)css单一样式:当需要下边距和左边距的时候,很多时候选择:margin:top 0 bottom 0;但margin-bottom:bot
tom;margin-left:left;执行的效率更高。
(3)减少使用@import,而建议使用link,因为后者在页面加载时一起加载,前者是等待页面加载完成之后再进行加载。

选择器性能:

(1)关键选择器(key selector)。选择器的最后面的部分为关键选择器(即用来匹配目标元素的部分)。CSS选择器是从右到
左进行匹配的。当使用后代选择器的时候,浏览器会遍历所有子元素来确定是否是指定的元素等等;

(2)如果规则拥有ID选择器作为其关键选择器,则不要为规则增加标签。过滤掉无关的规则(这样样式系统就不会浪费时间去匹
配它们了)。

(3)避免使用通配规则,如*{}计算次数惊人!只对需要用到的元素进行选择。

(4)尽量少的去对标签进行选择,而是用class。

(5)尽量少的去使用后代选择器,降低选择器的权重值。后代选择器的开销是最高的,尽量将选择器的深度降到最低,最高不要超过
三层,更多的使用类来关联每一个标签元素。

(6)了解哪些属性是可以通过继承而来的,然后避免对这些属性重复指定规则。

渲染性能:

(1)慎重使用高性能属性:浮动、定位。

(2)尽量减少页面重排、重绘。

(3)去除空规则:{}。空规则的产生原因一般来说是为了预留样式。去除这些空规则无疑能减少css文档体积。

(4)属性值为0时,不加单位。

(5)属性值为浮动小数0.**,可以省略小数点之前的0。

(6)标准化各种浏览器前缀:带浏览器前缀的在前。标准属性在后。

(7)不使用@import前缀,它会影响css的加载速度。

(8)选择器优化嵌套,尽量避免层级过深。

(9)css雪碧图,同一页面相近部分的小图标,方便使用,减少页面的请求次数,但是同时图片本身会变大,使用时,优劣考虑清
楚,再使用。

(10)正确使用display的属性,由于display的作用,某些样式组合会无效,徒增样式体积的同时也影响解析性能。

(11)不滥用web字体。对于中文网站来说WebFonts可能很陌生,国外却很流行。web fonts通常体积庞大,而且一些浏
览器在下载web fonts时会阻塞页面渲染损伤性能。

可维护性、健壮性:

(1)将具有相同属性的样式抽离出来,整合并通过class在页面中进行使用,提高css的可维护性。
(2)样式与内容分离:将css代码定义到外部css中。

35、浏览器是怎么样解析css选择器的?

样式系统从关键字选择器开始匹配,然后左移查找规则选择器的祖先元素,只要选择器的子树一直在工作,样式系统就会持续左移,直到和规则匹配,或者是因为不匹配而放弃该规则。

试想一下,如果采用从左到右的方式读取css规则,那么大多数规则读到最后才会发现是不匹配的,这样做会耗费性能,最后有很多都是无用的,而采用从右向左的方式,那么只要发现最后边浏览器不匹配,就可以直接舍弃了,避免了许多无效匹配。

36、在网页中应该使用奇数还是偶数的字体?为什么呢?

  1. 偶数字号相对于更容易和web设计的其他部分构成比例关系。比如,当我用了14px的正文字号,我可能会在一些地方用214x0.5=7px的margin,在另一些地方用14*1.5=21px的标题字号。
  2. 浏览器缘故,低版本的浏览器ie6会把奇数字体强制转换为偶数,即13px渲染为14px。
  3. 系统差别,早期的windows里,中易宋体点阵只有12、14、15和16,唯独缺少13px。

37、margin和padding分别适合什么场景使用?

margin是用来隔开元素域元素的间距;padding是用来隔开 元素和内容的间隔。
margin用于布局分开元素使元素与元素互不相干。
padding用于元素与内容之间的间隔,让内容(文字)与(包裹)元素之间有一段距离。

何时应该使用margin:
需要在border外侧添加空白的时候。
空白处不需要背景色的时候
上下相连接的两个盒子之间的空白,需要相互抵消的时候。如15px+20px的margin,讲的阿斗20px的空白。

何时应该使用padding
需要在border内侧添加空白时
空白处需要背景时
上下相连的两个盒子之间的空白,希望等于两者之和时。如15px+20px的padding,将得到35px的空白。

38、抽离样式模块怎么写,说出思路,有无实践经验?

我的理解是把常用的css样式单独做成css文件。通用的和业务相关的 分离出来,通用的做成样式模块儿共享,业务相关的,放进业务相关的库里面做成对应功能的模块儿。

39、简单说一下css3的all属性

all属性实际上是所有css属性的缩写,表示,所有的 css属性都怎么怎么样,但是,不包括unicode-bidi和direction这两个css属性。支持三个css通用属性值,initial,inherit,unset

initial是初始值的意思,也就是该元素除了unicode-bidi和direction以外的css属性都使用属性的默认初始值。

inherit是继承的意思,也就是该元素除了unicode-bidi和direction以外的css属性都继承父元素的属性值。

unset是取消设置的意思,也就是当前元素浏览器或者用户设置的css忽略,然后如果是具有继承特性的css,如color,则使用继承值。如果是没有继承特性的css属性,如background-color,则使用初始值。

40、为什么不建议使用通配符初始化css样式。

采用*{padding:0;margin:0;}这样的写法好处是写起来很简单,但是是通配符,需要把所有的标签都遍历一遍,当网站较大时,样式比较多,这样写就大大的加强了网站运行的负载,会使网站加载的时候需要很长一段时间,因此一般大型的网站都会有分层次的一套初始化样式。

出于性能的考虑,并不是所有标签都会有padding和margin,因此对常见的具有默认padding和margin的元素初始化即可,并不需要使用通配符*来初始化。

41、absolute和containingblock(包含块)计算方式跟正常流有什么不同?

  1. 内联元素也可以作为“包含块”所在元素。
  2. “包含块”所在元素不是父块级元素,而是最近的position不会static的祖先元素或根元素;
  3. 边界是padding box而不是content box。

42、对于hasLayout的理解?

hasLayout是IE特有的一个属性,很多的IE下的css bug都与其息息相关。在IE中,一个元素要么自己对自身的内容进行计算大小和组织,要么依赖于父元素来计算尺寸和组织内容。当一个元素的haslayout属性值为true时,它负责对自己和可能的子孙元素进行尺寸计算和定位。虽然这意味着这个元素需要花费更多的代价来维护自身和里面的内容,而不是依赖于祖先元素来完成这些工作。

43、元素竖向的百分比设定是 相对于容器的高度吗?

如果是height的话,是相对于包含块的高度。

如果是padding或者margin竖直方向的属性则是相对于包含块的宽度‘。

44、全屏滚动的原理是什么?用到了css的哪些属性?

原理:有点类似于轮播,整体的元素一直排列下去,假设有5个需要展示的全屏页面,那么高度是500%,只是展示100%,容器及容器内的页面取当前可视区高度,同时容器的父级元素overflow属性值设置为hidden,通过更改容器可视区的位置来实现全屏滚动效果。主要是响应鼠标事件,页面通过css的动画效果,进行滚动。

overflow:hidden;transition:all 1000ms ease;

45、什么是响应式设计?响应式设计的基本原理是什么?如何兼容低版本的IE?

响应式网站设计是一个网站能够兼容多个终端,而不是为每一个终端做一个特定的版本。基本原理是通过媒体查询检测不同的设备屏幕尺寸做处理。页面头部必须有meta声明的viewport。

46、视差滚动效果,如何给每页做不同的动画?(回到顶部,向下滑动要再次出现,和只出现一次分别怎么做?)

视差滚动是指多层背景以不同的速度移动,形成立体的运动效果,带来非常出色的视觉体验。

47、如何修改chrome记住密码后自动填充表单的黄色背景?

chrome表单自动填充后,input文本框的背景会变成黄色的,通过审查元素可以看到这是由于chrome会默认给自动填充的input表单加上input:-webkit-autofill私有属性,然后对其赋予一下样式:
{
background-color:rgb(250,255,189)!important;
background-image:none!important;
color:rgb(0,0,0)!important;
}
对chrome默认定义的background-color,background-image,color使用important是不能提高其优先级的,但是其他属性可以使用。

使用足够大的纯色内阴影来覆盖input输入框的黄色背景,处理如下:
input:-webkit-autofill,textarea:-webkit-autofill,select:-webkit-autofill{
-webkit-box-shadow:000px 1000px white inset;
border:1px solid #CCC !important;
}

48、怎么让Chrome支持小于12px的文字?

在谷歌下css设置字体大小为12px以及以下时,显示都是一样的大小,都是默认的12px。

解决办法:

  1. 可以使用webkit的内核-webkit-text-size-adjust的私有css属性来解决,只要加了-webkit-text-size-adjust:none;字体大小就不受限制了。但是chrome更新到27版本之后就不可使用了。所有高版本的chrome谷歌浏览器已经不再支持-webkit-text-size-adjust样式,所有使用时要慎用。
  2. 还可以使用css3的transform缩放属性-webkit-transform:scale(0.5);注意-webkit-transform:scale(2.75);收缩的是整个元素的 大小,这时候,如果是内联元素,必须要将内联元素转换成块元素,可以使用display:block/inline-block/…;
  3. 使用图片:如果是内容固定不变情况下,使用将小于12px文字内容切出做图片,这样不影响兼容也不影响美观。

49、让页面里的字体变清晰,变细用CSS怎么实现?

webkit内核的私有属性:-webkit-font-smoothing,用于字体抗锯齿,使用后字体看起来会更清晰舒服。

在MacOS测试环境下面设置-webkit-font-smoothing:antialiased;但是这个属性仅仅是面向MacOS,其他操作系统设置后无效。

50、font-style属性中italic和oblique的区别?

italic和oblique这两个关键字都表示"斜体"的意思。
它们的区别在于,italic是使用当前字体的倾斜字体,而oblique只是单纯的让文字倾斜。如果当前文字没有对应的倾斜字体,则退而求其次,解析为oblique,也就是单纯形状倾斜。

51、设备像素、css像素、设备独立像素、dpr、ppi之间的区别?

设备像素指的是物理像素,一般手机的分辨率指的就是设备像素,一个设备的设备像素是不可变的。
css像素和设备独立像素是等价的,不管在任何种分辨率的设备上,css像素的大小应该是一致的,css像素是一个相对单位,它是相对于设备像素的,一个css像素的大小取决于页面缩放程度和dpr的大小。

dpr指的是设备像素和设备独立像素的比值,一般的pc屏幕,dpr=1。在iphone4时,苹果推出了retina屏幕,它的dpr为2.屏幕的缩放会改变dpr的值。

ppi指的是每英寸的物理像素的密度,ppi越大,屏幕的分辨率越大。

52、layout viewport、visual viewport和ideal viewport的区别?

移动端一共需要理解三个viewport的概念的理解

第一个视口是布局视口,在移动端显示网页时,由于移动端的屏幕尺寸比较小,如果网页使用移动端的屏幕尺寸进行布局的话,那么整个页面的布局都会显示错乱。所以移动端浏览器提供了一个layout viewport布局视口的概念,使用这个视口来对页面进行布局展示,一般layout viewport的大小为980px,因此页面布局不会有太大的变化,我们可以通过拖动和缩放来查看到这个页面。

第二个视口指的是视觉视口,visual viewport指的时移动设备上我们可以见的区域的视口大小,一般为屏幕的分辨率的大小。visual viewport和laout viewport的关系,就像是我们通过窗户看外面的风景,视觉视口就是窗户,而外面的风景就是布局视口中的网页内容。

第三个视口是理想视口,由于layout viewport一般比visual viewport大,所以想要看到整个页面必须通过拖动和缩放才能实现。所以又提出了ideal viewport的概念,ideal viewport下用户不用缩放和滚动条 就能够查看整个页面,并且页面在不同分辨率下显示的内容大小相同。ideal viewport其实就是通过修改layout viewport的大小,让他等于设备的宽度,这个宽度可以理解为是设备独立像素,因此根据ideal viewport设计的页面,在不同分辨率的屏幕下,显示应该相同。

53、position:fixed;在Android下无效怎么办?

因为移动端浏览器默认的viewport叫做layout viewport。在移动端显示的时候,因为layout viewport的宽度大于移动端屏幕的宽度,所以页面会出现滚动条左右移动,fixed的元素是相对layout viewport来固定位置的,而不是移动端屏幕来固定位置的,所以会出现感觉fixed无效的情况。

如果想实现fixed相对屏幕的固定效果,我们需要改变的是viewport的大小为ideal viewport,可以如下设置:
<meta name=“viewport” content=“width=device-width,initial-scale=1.0,maximum-scale=1.0,minimum-sca
le=1.0,user-scalable=no”/ >

54、如果需要手写动画,你认为最小的事件间隔是多少,为什么?

多数显示器默认频率是60hz,即1秒刷新60次,所以理论上最小间隔为1/60*1000ms=16.7ms

55、如何去除inline-block元素间间距?

移除空格、使用margin负值、使用font-size:0、letter-spacing、word-spacing

56、overflow:scroll时不能平滑移动的问题怎么处理?

以下代码可以解决这种卡顿问题:-webkit-overflow-scrolling:touch;是因为这行代码启用了硬件加速特性,所以滑动很流畅。

57、有一个高度自适应的div,里面有两个div,一个高度100px,希望另一个填满剩下的高度。

  1. 外层div使用position:relative;高度要求自适应的div使用position:absolute;top:100px;bottom:0;left:0;right:0;
  2. 使用flex布局,设置主轴为竖轴,第二个div的flex-grow为1

58、png、jpg、gif这些图片格式解释一些,分别什么时候用。有没有了解过webp。

  1. jpeg(jpg):支持的颜色比较丰富,不支持透明效果,不支持动图。一般用来显示图片。
  2. gif:支持的颜色比较少,支持简单透明,支持动图。适用于颜色单一的图片、动图。
  3. png:支持的颜色丰富,支持复杂透明,不支持动图。专为网页而生。
  4. webp:这种格式是谷歌推出的专门用来表示网页中的图片的一种格式。使用webp格式的最大的优点是,在相同质量的文件下,它拥有更小的体积,因此它非常适合用于网络图片的传输,因为图片体积的减少,意味着请求时间的减小,这样会提高用户的体验。缺点是目前在兼容性问题上不太好。

选取图片规则:效果一样用小的,效果不一样用好的。

59、浏览器如何判断是否支持webp格式图片?

  1. 宽高判断法:通过创建image对象,将其src属性设置为webp格式的图片,然后再onload事件中获取图片的宽度,如果能够获取,则说明浏览器支持webp格式图片。如果不能获取或者触发了onerror函数,那么说明浏览器不支持webp格式的图片。
  2. canvas判断方法。我们可以动态地创建一个canvas对象,通过canvas的toDataURL将设置为webp格式,然后判断返回值中是否含有image/webp字段,如果包含则说明支持webp,反之则不支持。

60、什么是cookie隔离?(请求资源时不要让它带cookie怎么做)

网站向服务器请求的时候,会自动带上cookie,这样增加表头信息量,使请求变慢。
如果静态文件都放在主域名下,那静态文件请求的时候都带有的cookie的数据提交给server的,非常浪费流量,所以不如隔离开,静态资源放CDN。

因为cookie有域的限制,因此不能跨域提交请求,故使用非主域名的时候,请求头中就不会带有cookie数据,这样可以降低请求头的大小,降低请求时间,从而达到降低整体请求延时的目的。

同时这种方式不会将cookie传入webserver,也减少了webserver对cookie的处理分析环节,提高了webserver的http请求的解析速度。

61、style标签写在body后与body前有什么区别?

页面加载自上而下当然是先加载样式。写在body标签后由于浏览器以逐行方式对html文档进行解析,当解析到写在尾部的样式表(外联或者写在style标签)会导致浏览器停止之前的渲染,等待加载且解析样式表完成之后重新渲染,再windows的IE下可能会出现FOUC现象(即样式失效导致的页面闪烁问题(结构解析完成但是样式还没有解析完成))。

62、什么使CSS预处理器/后处理器?

CSS预处理器定义了一种新的语言,其基本思想是:用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标生成的文件,然后开发者就只要使用这种语言进行编码工作。通俗的说,css预处理器用一种专门的编程语言,进行Web页面样式设计,然后再编译成正常的CSS文件。

预处理器例如:less、sass、stylus,用来编译sass或者less,增强了css代码的复用性,还有层级、mixin、变量、循环、函数等,具有很方便的UI组件模块化开发能力,极大的提高工作效率。

CSS后处理器是对CSS进行处理,并最终生成CSS的预处理器,它属于广义上的CSS预处理器。我们很久以前就在用CSS后处理器了,比如CSS压缩工具(clean-css),只不过以前没有单独拿出来说过,还有最近比较火的Autoprefixer,以caniuse上的浏览器支持数据为基础,自动处理兼容性问题。

后处理器例如:postcss,通常被视为在完成的样式表中根据css规范处理css,让其更有效;目前最常做的是给css属性添加浏览器私有前缀,实现跨浏览器兼容性的问题。

63、阐述一下CSS Sprites

将一个页面涉及到的所有图片都包含到一张大图中取,然后利用CSS的background-image,background-repeat,background-position的组合进行背景定位。利用css Sprites能很好地减少网页的http请求,从而很好的提高页面的性能。
CSS Sprites能够减少图片的字节。
优点:
减少HTTP请求书,极大的提高页面加载速度
增加图片信息重复度,提高压缩比,减少图片大小。
更换风格方便,只需要在一张或者几张图片上修改颜色或样式即可实现。

缺点:
图片合并麻烦。
维护麻烦,修改一个图片可能需要重新布局整个图片、样式。

64、使用rem布局的优缺点?

优点:
在屏幕分辨率千差万别的时代,只要将rem与屏幕分辨率关联起来就可以实现页面的整体缩放,使得在设备上的展现都统一起来了。
而且现在浏览器基本都已经支持rem了,兼容性也非常的好。

缺点:

  1. 在奇葩的dpr设备上表现效果不啊太好,比如一些华为的高端机型用rem布局会出现错乱。
  2. 使用iframe引用也会出现问题。
  3. rem在多屏幕尺寸适配上与当前两大平台的设计哲学不一致。即大屏的出现到底是为了看的又大又清楚,还是为了看到更多的问题。

65、几种常见的CSS布局

圣杯布局:

  1. 比较特殊的三栏布局,同样也是两边固定宽度,中间自适应,唯一的区别是dom结构必须是先写中间列部分,这样实现中间列可以优先加载。
  2. 三个部分都设为左浮动,否则左右两边内容上不去,就不可能与中间列同一行,然后设置center的宽度为100%(实现中间列内容自适应),此时,left和right部分会跳到下一行。
  3. 通过设置margin-left为负值让left和right部分回到与center同一行。
  4. 通过设置父容器的padding-left和padding-right,让左右两边留出间隙。
  5. 通过设置相对定位,让left和right部分移动到两边。
    圣杯布局的缺点:
    center部分的最小宽度不能小于left部分的宽度,否则会left部分掉到下一行
    如果其中一列内容高度拉长, 其他两列的背景并不会自动填充(借助等高布局正padding+负margin可解决,下文会介绍)

双飞翼布局:

  1. 同样也是三栏布局,在圣杯布局的基础上进一步优化,解决了圣杯布局错乱问题,实现了内容与布局的分离。而且任何一栏都可以是最高栏,不会出现问题。
  2. 实现步骤(前两步与圣杯布局一样) 三个部分都设定为左浮动,然后设置center的宽度为100%,此时,leftheright部分回跳到下一行;通过设置margin-left为负值让left和right部分回到与center部分同一行;center部分增加一个内层div,并设margin: 0 200px。

双飞翼布局的缺点:多加一层dom树节点,增加渲染树生成的计算量。

两种布局实现方式对比:

  • 两种方式都是把主列放在文档流最前面,使主列优先加载。
  • 两种布局方式在实现上也有相同之处,都是让三列浮动,然后通过负外边距形成三列布局。
  • 两种布局方式的不同之处在于如何处理中间主列的位置:圣杯布局是利用父容器的左、右内边距+两个从列相对定位;双飞翼布局是把主列嵌套在一个新的父级块中利用主列的左、右外边距进行布局调整。

66、画一条0.5px的线

采用meta viewport方式
采用border-image的方式

采用transform:scaleY()的方式//注意chrome下实现变虚的问题,可以通过设置transform
-origin:50% 100%解决

67、transition和animation的区别

transition关注的是css property的变化,property值和时间的关系是一个三次贝塞尔曲线。一般结合transforms使用,animation作用于元素本身而不是样式属性,可以使用关键帧的概念,应该说可以实现更自由地动画效果。

68、什么是首选最小宽度?

首选最小宽度指的是元素最适合的最小宽度。
东亚文字(如中文)最小宽度为每个汉字的宽度。
西方文字最小宽度由特定的连续的英文字符单元决定。并不是所有的英文字符都会组成连续单元,一般会终止与空格(普通空格)、短横线、问号以及其他非英文字符等。

如果想让英文字符和中文一样,每一个字符都用最小宽度单元,可以试试使用css中的word-break:break-all。

69、为什么height:100%会无效?

对于普通文档流中的元素,百分比高度值要想起作用,其父级必须有一个可以生效的高度值。原因是如果包含块的高度没有显式指定(即高度由内容决定),并且该元素不是绝对定位,则计算值为auto,因为解释了auto,所以无法参与计算。
使用绝对定位的元素会有计算值,即使祖先元素的height计算为auto也是如此。

70、min-width/max-width和min-height/max-height属性间的覆盖规则?

  1. max-width会覆盖width,即使width是行类样式或者设置了!important
  2. min-width会覆盖max-width,此规则发生在min-width和max-width冲突的时候。

71、内联盒模型基本概念

  1. 内容区域(content area)。内容区域指一种围绕文字看不见的盒子,其大小仅受字符本身特性控制,本质上是一个字符盒子(character box);但是有些元素,如图片这样的替换元素,其内容不是文字,不存在字符盒子之类的,因此,对于这些元素,内容区域可以看成元素自身。
  2. 内联盒子(inline box)。"内联盒子"不会让内容成块显示,而是排成一行,这里的“内联盒子”实际上指的是元素的“外在盒子”,用来决定元素是内联还是块级。该盒子又可以细分为“内联盒子”和“匿名内联盒子”两类。
  3. 行框盒子(line-box),每一行就是一个“行框盒子”(实线框标注),每个“行框盒子”又是由一个一个“内联盒子”组成的 。
  4. 包含块(containing box),由一行一行的“行框盒子:组成。

72、什么是幽灵空白节点?

“幽灵空白节点”是内联盒模型中非常重要的一个概念,具体指的是:在HTML5文档声明中,内联元素的所有解析和渲染表现就如同每个行框盒子的前面有一个“空白结点”一样,这个“空白节点”永远透明,不占据任何宽度,看不见也无法通过脚本获取,就好像幽灵一样,但又确确实实地存在,表现如同文本节点一样,因此,我称之为“幽灵空白节点”。

73、什么是替换元素?

通过修改某个属性值呈现的内容就可以被替换的元素就称为“替换元素”。因此,< img >、< object >、< video >、< iframe >或者表单元素< textarea >和 < input > < select >都是典型的替换元素。

替换元素除了内容可以替换这一特性之外,还有以下一些特性:

  1. 内容的外观不受页面上的CSS的影响。用专业的话讲就是样式表现在CSS作用域之外。如何更改替换元素本身的外观需要类似appearance属性,或者浏览器自身暴露的一些样式接口。
  2. 有自己的尺寸,在web中,很多替换元素在没有明确尺寸设定的情况下,其默认的尺寸(不包括边框)是300像素*150像素,如< video >、< iframe >、< canvas >等,也有少部分替换元素为0像素,如< img >图片,而表单元素的替换元素的尺寸则和浏览器有关,没有明显的规律。
  3. 在很多css属性上有自己的一套表现规则。比较具有代表性的就是vertical-align属性,对于替换元素和非替换元素,vertical-align属性值的解释是不一样的,比方说vertical-align属性值的解释是不一样的。比方说vertical-align的默认值的baseline,很简单的属性值,基线之意,被定义为字符x的下边缘,而替换元素的基线却被硬生生定义成了元素的下边缘。
  4. 所有的替换元素都是内联水平元素,也就是替换元素和替换元素、替换元素和文字都是可以在一行显示的。但是,替换元素默认的display值确实不一样的,有的是inline,有的是inline-block

74、替换元素的计算规则?

替换元素的尺寸从内而外分成3类:固有尺寸、html尺寸和css尺寸。

  1. 固有尺寸指的是替换内容原本的尺寸。例如,图片、视频作为一个独立文件存在的时候,都是有着自己的宽度和高度的。
  2. html尺寸只能通过html原生属性改变,这些html原生属性包括< img>的width和height属性、< input>的size属性、< textarea >的cols和rows属性等。
  3. css尺寸特质可以通过css的width和height或者max-width/min-width和max-height/min-height设置的尺寸,对应盒尺寸中的content box。

这3层结构的计算规则如下:
如果没有css尺寸和html尺寸,则使用固有尺寸作为最终的宽高。
如果没有css尺寸,则使用html尺寸作为最终的宽高。
如果有css尺寸,则最终尺寸由css属性决定。
如果“固有尺寸:含有固有的宽高比例,同时仅设置了宽度或仅设置了高度,则元素依然按照固有的宽高比例显示。
如果上面的条件都不符合,则最终宽度表现为3–像素,高度为150像素。
内联替换元素和块级替换元素使用上面同一套尺寸计算规则。

75、content与替换元素的关系?

content属性生成的对象称为“匿名替换元素”。

  1. 我们使用content生成 的文本是无法选中】无法复制的,好像设置了user select:none声明一样,但是普通元素的文本却可以被轻松选中。同时,content生成的文本无法被屏幕阅读设备读取,也无法被搜索引擎抓取,因此,千万不要自以为是地把重要的文本信息使用content属性生成,因为这对可访问性和SEO都不是很友好
  2. content生成的内容不能左右:empty伪类。
  3. content动态生成值无法获取。

76、margin:auto的填充规则?

margin的auto可不是摆设,是具有强烈的计算意味的关键字,用来计算元素对应方向应该获得的剩余间距大小。但是触发margin:auto计算有一个前提条件,就是width或height为auto时,元素是具有对应方向的自动填充特性的。

  1. 如果一侧定值,一侧auto,auto为剩余空间大小
  2. 如果两侧均是auto,则评分剩余空间。

77、margin无效的情形

  1. display计算值inline的非替换元素的垂直margin是无效的,对于内联替换元素,垂直margin有效,并且没有margin合并的问题。
  2. 表格中的< tr >和< td >元素或者设置display计算值是table-cell或者table-row的元素的margin都是无效的。
  3. 绝对定位元素非定位方位的margin值无效。
  4. 定高容器的子元素的margin-bottom或者宽度定死的子元素的margin-right的定位“失效”。

78、border的特殊性?

  1. border-width却不支持百分比。
  2. border-style的默认值是none,有一部分人可能会误以为是solid。这也是单纯设置border-width或者border-color没有边框显示的原因。
  3. border-style:double的表现规则:双线宽度永远相等,中间间隔正负1
  4. border-color默认颜色就是color色值
  5. 默认background背景图片是相对于padding box定位的。

79、什么是基线和x-height?

字母x的下边缘(线)就是我们的基线。
x-height指的就是小写字母x的高度,术语描述就是基线和等分线(meanline)(也称作中线,midline)之间的距离。在CSS世界中,middle指的是基线网上1/2x-height高度,我们可以近似理解为字母x交叉点那个位置。
ex是css中的一个相对单位,指的是小写字母x的高度,没错,就是指x-height。ex的价值就在其副业上不受字体和字号影响的内联元素的垂直居中对齐效果。内联元素默认是基线对齐的,而基线就是x的底部,而1ex就是一个x的高度。

80、line-height的特殊性?

  1. 对于非替换元素的纯内联元素,其可视高度完全由line-height决定。对于文本这样的纯内联元素,line-height就是高度计算的基石,用专业说法就是指定了用来计算行框盒子高度的基础高度。
  2. 内联元素的高度由固定高度和不固定高度组成,这个不固定的部分就是这里的“行距:。换句话说,line-height之所以起作用,就是通过改变“行距”来实现的。在css中,“行距”分散在当前文字的上方和下方,也就是即使是第一行文字,其上方也是有“行距”的,只不过这个“行距”的高度仅仅是完整“行距”高度的一半。因此也被称为“半行距”。
  3. 行距=line-height - font-size
  4. border以及line-height等传统css属性并没有小数像素的概念。如果标注的是文字上边距,则向下取整。如果是文字下边距,则向上取整。
  5. 对于纯文本元素,line-height直接决定了最终的高度。但是,如果同时有替换元素,则line-height只能决定最小高度。
  6. 对于块级元素,line-heighe对其本身是没有任何作用的,我们平时改变line-height,块级元素的高度跟着变化实际上是通过改变块级元素里面内敛级别元素占据的高度实现的。
  7. line-height的默认值是normal,还支持数值、百分比值以及长度值。为数值类型时,其最终计算值时和当前font-size相乘后的值。为长度值时原意不变。
  8. 如果使用数值作为line-height的属性值,那么所有的 子元素继承的都是这个值。但是,如果使用百分比值或者长度值作为属性值,那么所有的子元素继承的是最终的计算值。
  9. 无论内联元素line-height如何设置,最终父级元素的高度都是由数值大的那个line-height决定的。
  10. 只要有“内联盒子”在,就一定会有一个“行框盒子”,就是每一行内联元素外面包裹的一层看不见的盒子。然后,重点来了,在每个“行框盒子”前面有一个宽度为0的具有该元素的字体和行高属性的看不见的“幽灵空白节点”。

81、vertical-align的特殊性?

  1. vertical-align的默认值是baseline,基线对齐,而基线的定义是字母x的下边缘。因此,内联元素默认都是沿着字母x的下边缘对齐的。对于图片等替换元素,往往使用元素本身的下边缘作为基线。一个inline-block元素,如果里面没有内联元素,或者overflow不是visible,则该元素的基线就是margin底边缘;否则其基线就是元素里面最后一行内联元素的基线。
  2. vertical-align:top就是垂直上边缘对齐,如果是内联元素,则和这一行位置最高的内联元素的顶部对齐;如果是display计算值是table-cell的元素,我们不妨脑补成< td >元素,则和< tr >元素上边缘对齐。
  3. vertical-align:middle是中间对齐,对于内联元素,元素的垂直中心点和行框盒子基线往上1/2x-height处对齐。对于table-cell元素,单元格填充盒子相对于外面的表格行居中对齐,
  4. vertical-align支持数值属性,根据数值的不同,相对于基线往上或往下偏移,如果是负值,往下偏移,如果是正值,往上偏移。
  5. vertical-align属性的百分比值则是相对于line-height的计算值计算的。
  6. vertical-align起作用是有前提条件的,这个前提条件就是:只能应用于内联元素以及display值为table-cell的元素。
  7. table-cell元素设置vertical-align垂直对齐的是子元素,但是其作用的并不是子元素,而是table-cell元素自身。

82、overflow的特殊性?

  1. 一个设置了overflow:hidden声明的元素,假设同时存在border属性和padding属性,则当子元素内容超出容器宽度高度限制的时候,剪裁的边界是border box的内边缘,而非padding box的内边缘。
  2. html中有两个标签是默认可以产生滚动条的,一个是根元素< html>,另一个是文本域< textarea>。
  3. 滚动条会占用容器的可用宽度或高度。
  4. 元素设置了overflow:hidden声明,里面内容高度溢出的时候,滚动仍然存在,仅仅滚动条不存在!

83、无依赖绝对定位是什么?

没有设置left/top/right/bottom属性值的绝对定位称为“无依赖绝对定位”。
无依赖绝对定位其定位的位置和没有设置position:absolute时候的位置相关。

84、absolute与overflow的关系?

  1. 如果overflow不是定位元素,同时绝对定位元素和overflow容器之间也没有定位元素,则overflow无法对absolute元素进行剪裁。
  2. 如果overflow的属性值不是hidden而是auto或者scroll,即使绝对定位元素高宽比overflow元素高宽还要大,也都不会出现滚动条。
  3. overflow元素自身transform的时候,chrome和opera浏览器下的overflow剪裁是无效的。

85、clip裁剪是什么?

所谓可访问性隐藏,指的是虽然内容肉眼看不见,但是其他辅助设备却能够识别和访问的隐藏。
clip剪裁被我称为“最佳可访问性隐藏”的另外一个原因就是i,它具有更强的普遍适应性,任何元素、任何场景都可以无障碍使用。

86、relative的特殊性?

  1. 相对元素的left/top/right/bottom的百分比值是相对于包含块计算的,而不是自身。注意,虽然定位位移是相对自身,但是百分比值的计算值不是。
  2. top和bottom这两个垂直方向的百分比值计算跟height的百分比值是一样的,都是相对高度计算的。同时,如果包含块的高度是auto,那么计算值是0,偏移无效,也就是说,如果父元素没有设定高度或者不是“格式化高度”,那么relative类似top:20%的代码等同于top:0.
  3. 当相对定位元素同时应用对立方向定位值的时候,也就是top/bottom和left/right同时使用的时候,只有一个方向的定位属性会起作用。而谁起作用则是与文档流的顺序有关的,默认的文档流是自上而下、从左往右,因此top/bottom同时使用的时候,bottom失效;left/right同时使用的时候,right失效。

87、什么是层叠上下文?

层叠上下文,英文称作stacking context,是html中的一个三维的概念。如果一个元素含有层叠上下文,我们可以理解这个元素在z轴上就“高人一等”。

层叠上下文元素有如下特性:

  1. 层叠上下文的层叠水平比普通元素高。
  2. 层叠上下文可以阻断元素的混合模式。
  3. 层叠上下文可以嵌套,内部层叠上下文及其所有子元素均受制于外部层叠上下文。
  4. 每个层叠上下文和兄弟元素独立,也就是说,当金星层叠变化或渲染的时候,只需要考虑后代元素。
  5. 每个层叠上下文是自成体系的,当元素发生层叠的时候,整个元素被认为是在父层叠上下文的层叠顺序中。

层叠上下文的创建:
页面根元素天生具有层叠上下文,称为根层叠上下文。根层叠上下文指的是页面根元素,可以看成是html元素,因此,页面中所有的元素一定处于至少一个“层叠结界”中。
对于position值为relative/absolute以及firefox/ie浏览器(不包括chrome浏览器)下含有position:fixed声明的定位元素,当其z-index值不是auto的时候,会创建层叠上下文。chrome等webkit内核浏览器下,position:fixed元素天然层叠上下文元素,无需z-index为数值。根据我的测试,目前IE和firefox仍是老套路。
其他一些css3属性,比如元素的opacity值不是1.

88、什么是层叠水平?

层叠水平,英文称作stacking level,决定了同一个层叠上下文中元素在z轴上的显示顺序。
显而易见,所有的元素都有层叠水平,包括层叠上下文元素,也包括普通元素。然而,对普通元素水平探讨只局限在当前层叠上下文元素中。

89、元素的层叠顺序?

层叠顺序,英文称作stacking order,表示元素发生层叠时有着特定的垂直显示顺序。

在这里插入图片描述

90、层叠准则?

  1. 谁大谁上:当具有明显的层叠水平标识的时候,如生效的z-index属性值,在同一层叠上下文领域,层叠水平值大的那一个覆盖小的那一个。
  2. 后来居上:当元素的层叠水平一致、层叠顺序相同的时候,在DOM流中处于后面的元素会覆盖前面的元素。

91、font-weight的特殊性?

如果使用数值作为font-weight属性值,必须是100~900的整百数。因为这里的数值仅仅是外表长得像数值,实际上是具有特定含义的关键字,并且这里的数值关键字和字母关键字之间是有对应关系 的。一般使用font-weight:bold来加粗。

92、text-indent的特殊性?

  1. text-indent仅对第一个行内联盒子内容有效。
  2. 非替换元素以外的display计算值为inline的内联元素设置为text-indent值无效,如果计算值inline-block/inline-table则会生效。
  3. < input >标签按钮tex-indent值无效。
  4. < button >标签按钮text-indent值有效。
  5. text-indent的百分比值是相对于当前元素的“包含块”计算的,而不是当前元素。

93、letter-spacing与字符间距?

letter-spacing可以用来控制字符之间的间距,这里说的“字符”包括英文字母、汉字以及空格等。
letter-spacing具有以下一些特性。

  1. 继承性
  2. 默认值是normal而不是0.虽然说正常情况下,normal的计算值就是0,但两者还是有差别的,在有些场景下,letter-spacing会调整normal的计算值以实现更好的版面布局。
  3. 支持负值,且值足够大的时候,会让字符形成重叠,甚至反向排列。
  4. 和text-indent属性一样,无论值多大或多小,第一行一定会保留至少一个字符。
  5. 支持小数值,即使0.1px也是支持的。
  6. 暂不支持百分比值。

94、word-spacing与单词间距?

letter-spacing作用于所有字符,但word-spacing仅作用于空格字符,换句话说,word-spacing的作用就是增加空格的间隙宽度。

95、white-space与换行和空格的控制?

whiter-space属性声明了和处理元素内空白字符,这类空白字符包括space键、enter键、tab键产生的空白。因此,white-space可以决定图文内容是否在一行显示(回车空格是否生效),是否显示大段连续空白(空格是否生效)等。

其属性值包括下面这些:

  • normal:合并空白字符和换行字符
  • pre:空白字符不合并,并且内容只有在换行符的地方换行。
  • nowrap:该值和normal一样会合并空白字符,但不允许文本环绕。
  • pre-wrap:空白字符不合并,并且内容只有在换行符的地方换行,同时允许文本环绕。
  • pre-line:合并空白字符,但只有在换行符的地方换行,允许文本环绕。

96、隐藏元素的background-image到底加不加载?

  1. 元素的背景图片。元素本身设置display:none,会请求图片-父级元素设置display:none,不会请求图片;样式没有元素使用,不会请求;:hover样式下,触发时请求
  2. img标签图片任何情况下都会请求图片。

97、如何实现单行/多行文本溢出的省略?

/单行文本溢出/
p {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}

/多行文本溢出/
p {
position: relative;
line-height: 1.5em;
/高度为需要显示的行数行高,比如这里我们显示两行,则为3*/
height: 3em;
overflow: hidden;
}

p:after {
content: ‘…’;
position: absolute;
bottom: 0;
right: 0;
background-color: #fff;
}

98、常见的元素隐藏的方式?

  1. 使用display:none隐藏元素,渲染树不会包含该渲染对象,因此该元素不会在页面中占据位置,也不会影响绑定的监听事件。
  2. 使用visibility:hidden;隐藏元素。元素在页面中仍然占据空间,但是不会响应绑定的监听事件。
  3. 使用opacity:0;将元素的不透明度设置为0,以此来实现元素的隐藏。元素在页面中仍然占据空间,并且能够响应元素绑定的监听事件。
  4. 通过z-index负值,来使其他元素遮盖住该元素,以此来实现隐藏。
  5. 通过clip/clip-path元素裁剪的方法来实现元素的隐藏,这种方法下,元素仍在页面中占据位置,但是不会响应绑定的监听事件。
  6. 通过通过使用绝对定位将元素移除可视区域内,以此来实现元素的隐藏。
  7. 通过transform:scale(0,0)来将元素缩放为0,以此来实现元素的隐藏。这种方法下,元素仍在页面中占据位置,但是不会影响绑定的监听事件。

99、css实现上下固定中间自适应布局?

利用绝对定位实现
body {
padding: 0;
margin: 0;
}

.header {
position: absolute;
top: 0;
width: 100%;
height: 100px;
background: red;
}

.container {
position: absolute;
top: 100px;
bottom: 100px;
width: 100%;
background: green;
}

.footer {
position: absolute;
bottom: 0;
height: 100px;
width: 100%;
background: red;
}

利用flex布局实现
html,
body {
height: 100%;
}

body {
display: flex;
padding: 0;
margin: 0;
flex-direction: column;
}

.header {
height: 100px;
background: red;
}

.container {
flex-grow: 1;
background: green;
}

.footer {
height: 100px;
background: red;
}

100、css两栏布局的实现?

两栏布局一般指的是页面中一共两栏,左边固定,右边自适应的布局,一共有四种实现方式。
以左边宽度固定为200px为例。

  1. 利用浮动。将左边元素宽度设置为200px,并且设置向左浮动。将右边元素的margin-left设置为200px,宽度设置为auto(默认为autp,撑满整个父元素)
  2. 第二种是利用flex布局,将左边元素宽度设置为200px,将右边的元素的放大比例设置为1.
  3. 第三种是利用绝对定位布局的方式,将父级元素设置相对定位。左边元素设置为absolute定位,并且宽度设置为200px。将右边元素的margin-left的值设置为200px。
  4. 第四种还是利用绝对定位的方式,将父级元素设置为相对定位,左边元素宽度设置为200px,右边元素设置为绝对定位,左边定位为200px,其余方向定位为0。

101、css三栏布局的实现?

三栏布局一般指的是页面中一共有三栏,左右两栏宽度固定,中间自适应的布局,一共有五种实现方式。
这里以左边宽度固定为100px,右边宽度固定为200px为例。

  1. 利用绝对定位的方式,左右两栏设置为绝对定位,中间设置为对应方向大小的margin的值。
  2. 采用flex布局的方式,左右两栏的宽度分别设置为100px和200px,中间一栏增长系数设置为1.
  3. 利用浮动的方式,左右两栏设置固定大小,并设置对应方向的浮动,中间一栏设置左右两个方向的margin值,注意这种方式,中间一栏必须放到最后。
  4. 圣杯布局。利用浮动和负边距来实现。父级元素设置左右的padding,三列均设置向左浮动,中间一列放在最前面,宽度设置为父级元素的宽度,因此后面两列都被挤到了下一行,通过设置margin负值将其移动到上一行,再利用相对定位,定位到两边。圣杯布局中间列的宽度不能小于左边列的宽度,否则左边列不上去,而双飞翼布局则不存在这个问题
  5. 双飞翼布局,双飞翼布局相对于圣杯布局来说,左右位置的保留是通过中间列的margin值来实现的,而不是通过父元素的padding来实现的。本质上是,也就是通过浮动和外边距负值来实现的

102、实现一个宽高自适应的正方形。

/1.第一种方式是利用vw来实现/
.square {
width: 10vw;
height: 10vw;
background: tomato;
}

/2.第二种方式是利用元素的margin/padding百分比是相对父元素width的性质来实现/
.square {
width: 20%;
height: 0;
padding-top: 20%;
background: orange;
}

/3.第三种方式是利用子元素的margin-top的值来实现的/
.square {
width: 30%;
overflow: hidden;
background: yellow;
}

.square::after {
content: ‘’;
display: block;
margin-top: 100%;
}

103、实现一个三角形

/三角形的实现原理是利用了元素边框连接处的等分原理。/
.triangle {
width: 0;
height: 0;
border-width: 100px;
border-style: solid;
border-color: transparent transparent tomato;
}

104、一个自适应矩形,水平垂直居中,且宽高比为2:1

/实现原理参考自适应正方形和水平居中方式/
.box {
position: absolute;
top: 0;
right: 0;
left: 0;
bottom: 0;
margin: auto;

width: 20%;
height: 10vw;
background: tomato;
}

105、你知道CSS中不同属性设置为百分比%时对应的计算基准?

公式:当前元素某css属性值=基准*对应的百分比
元素的position为relative和absolute时,top和bottom、left和right基准分别包含块的height、width
元素的position为fixed时,top和bottom、left和right基准分别为初始包含块(也就是视口)的height、width,
移动设备较为复杂,基准为layout viewport的height、width
元素的height和width设置为百分比时,基准分别为包含块的height和width
元素的margin和padding设置为百分比时,基准为包含块的width(易错)
元素的border-width,不支持百分比
元素的text-indent,基准为包含块的width
元素的border-radius,基准为分别为自身的height、width
元素的background-size,基准为分别为自身的height、width
元素的translateX、translateY,基准为分别为自身的height、width
元素的line-height,基准为自身的font-size
元素的font-size,基准为父元素字体。