Skip to content

Latest commit

 

History

History
1622 lines (1159 loc) · 57.6 KB

CSSQuestions.md

File metadata and controls

1622 lines (1159 loc) · 57.6 KB

CSS相关问题

元素/类

CSS 中类 (classes) 和 ID 的区别。

  • ID唯一,CSS用#选择
  • 类不唯一,CSS用.选择

CSS选择器有哪些

  1. *通用选择器:选择所有元素,不参与计算优先级,兼容性IE6+
  2. #X id选择器:选择id值为X的元素,兼容性:IE6+
  3. .X 类选择器: 选择class包含X的元素,兼容性:IE6+
  4. X Y后代选择器: 选择满足X选择器的后代节点中满足Y选择器的元素,兼容性:IE6+
  5. X 元素选择器: 选择标所有签为X的元素,兼容性:IE6+
  6. :link,:visited,:focus,:hover,:active链接状态: 选择特定状态的链接元素,顺序LoVe HAte,兼容性: IE4+
  7. X + Y直接兄弟选择器:在X之后第一个兄弟节点中选择满足Y选择器的元素,兼容性: IE7+
  8. X > Y子选择器: 选择X的子元素中满足Y选择器的元素,兼容性: IE7+
  9. X ~ Y兄弟: 选择X之后所有兄弟节点中满足Y选择器的元素,兼容性: IE7+
  10. [attr]:选择所有设置了attr属性的元素,兼容性IE7+
  11. [attr=value]:选择属性值刚好为value的元素
  12. [attr~=value]:选择属性值为空白符分隔,其中一个的值刚好是value的元素
  13. [attr|=value]:选择属性值刚好为value或者value-开头的元素
  14. [attr^=value]:选择属性值以value开头的元素
  15. [attr$=value]:选择属性值以value结尾的元素
  16. [attr=value]:选择属性值中包含value的元素
  17. [:checked]:选择单选框,复选框,下拉框中选中状态下的元素,兼容性:IE9+
  18. X::before, X::after:after伪元素,选择元素虚拟子元素(元素的最后一个子元素),CSS3中::表示伪元素。兼容性:after为IE8+,::after为IE9+
  19. :not(selector):选择不符合selector的元素。不参与计算优先级,兼容性:IE9+
  20. ::first-letter:伪元素,选择块元素第一行的第一个字母,兼容性IE5.5+
  21. ::first-line:伪元素,选择块元素的第一行,兼容性IE5.5+
  22. :nth-child(an + b):伪类,选择前面有an + b - 1个兄弟节点的元素,其中n >= 0, 兼容性IE9+
  23. :nth-last-child(an + b):伪类,选择后面有an + b - 1个兄弟节点的元素 其中n >= 0,兼容性IE9+
  24. X:nth-of-type(an+b):伪类,X为选择器,解析得到元素标签,选择前面有an + b - 1个相同标签兄弟节点的元素。兼容性IE9+
  25. X:nth-last-of-type(an+b):伪类,X为选择器,解析得到元素标签,选择后面有an+b-1个相同标签兄弟节点的元素。兼容性IE9+
  26. X:first-child:伪类,选择满足X选择器的元素,且这个元素是其父节点的第一个子元素。兼容性IE7+
  27. X:last-child:伪类,选择满足X选择器的元素,且这个元素是其父节点的最后一个子元素。兼容性IE9+
  28. X:only-child:伪类,选择满足X选择器的元素,且这个元素是其父元素的唯一子元素。兼容性IE9+
  29. X:only-of-type:伪类,选择X选择的元素,解析得到元素标签,如果该元素没有相同类型的兄弟节点时选中它。兼容性IE9+
  30. X:first-of-type:伪类,选择X选择的元素,解析得到元素标签,如果该元素 是此此类型元素的第一个兄弟。选中它。兼容性IE9+

请解释浏览器是如何判断元素是否匹配某个 CSS 选择器?

从后往前判断,因为CSS选择器的规则肯定小于元素集合数量,所以遍历选择器规则来过滤元素集合是比较快捷,至于为什么从后往前,主要是元素集合是树形结构,查找兄弟元素和父元素更为方便。

请描述伪元素 (pseudo-elements) 及其用途。

伪元素不是真正的元素,所以JS不能操作伪元素,但CSS选择器可以选择并为其设置样式。

  • ::after
  • ::before 这两个伪元素通常用来清除浮动/为元素添加背景或其他样式的美化
  • ::first-letter
  • ::first-line 这两个伪元素则是选择部分内容进行样式改变
  • ::selection 选择文档中被用户高亮的部分,处于CSS3中第4级伪元素。

另外还有伪类(pseudo-classes),CSS伪类是添加到选择器的关键字,指定要选择的元素的特殊状态。伪类数量比较多:

伪类与伪元素的区别

CSS 伪元素:逻辑上存在但在文档树中却无须标识的“幽灵”分类 CSS 伪元素(:first-letter,:first-line,:after,:before)代表了某个元素的子元素,这个子元素虽然在逻辑上存在,但却并不实际存在于文档树中。 CSS3标准要求伪元素使用双冒号

伪类用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。

a:link
:first-child
:nth-child
:focus
:visited

CSS 中字母 'C' 的意思是叠层 (Cascading)。请问在确定样式的过程中优先级是如何决定的 (请举例)?如何有效使用此系统?

  • 选择器的优先级10,按以下位数计数法的权重规则排列:
    • 0 类型选择器
    • 1 类选择器/属性选择器/伪类
    • 2 ID选择器
    • 通用选择器(*)/组合选择(+ > ~ )对选择器优先级没有影响
  • 优先级相同时后声明样式优先级高于先声明样式
  • 内联样式优先级高于外部样式
  • !important 样式优先级高于任何样式,尽量避免使用

哪些属性可继承?哪些不可?

可继承属性

替换元素与非替换元素

元素是文档结构的基础,在CSS中,每个元素生成了一个包含了元素内容的框。但是不同的元素显示的方式会有所不同,例如div和span不同,而strong和p也不一样。在文档类型定义(DTD)中对不同的元素规定了不同的类型,这也是DTD对文档之所以重要的原因之一。而根据元素本身的特点可以分为替换元素(replaced element)和非替换元素,非替换元素,在W3C中没有给出明确的定义,但我们可以由替换元素对应着非替换元素,所以可以理解为除了替换元素,其它的就是非替换元素。

  • 替换元素

    CSS 里,可替换元素(replaced element)的展现不是由CSS来控制的。这些元素是一类 外观渲染独立于CSS的 外部对象。 典型的可替换元素有 <img>、 <object>、 <video> 和 表单元素,如<textarea>、 <input> 。 某些元素只在一些特殊情况下表现为可替换元素,例如 <audio><canvas> 。 通过 CSS content 属性来插入的对象 被称作 匿名可替换元素(anonymous replaced elements)。

    CSS在某些情况下会对可替换元素做特殊处理,比如计算外边距和一些auto值。

    需要注意的是,一部分(并非全部)可替换元素,本身具有尺寸和基线(baseline),会被像vertical-align之类的一些 CSS 属性用到。

    替换元素就是浏览器根据元素的标签和属性,来决定元素的具体显示内容,替换元素是其内容不受CSS视觉格式化模型控制的。比如img元素通过src属性的值来读取图片信息并显示出来,而如果查看(x)html代码,却看不到图片的实际内容,而且img元素的内容通常会被src属性指定的图像替换掉;例如input元素的type属性决定是显示输入框,还是单选按钮等。(x)html中的img , input , textarea , select , object都是替换元素。这些元素没有实际的内容,即是个空元素

    浏览器会根据元素的标签类型和属性来显示这些元素。替换元素也在其显示中生成了框。所以,替换元素通常有其固有的尺寸:一个固有的宽度,一个固有的高度和一个固有的比率;CSS渲染模型不考虑替换元素内容的渲染。这些替换元素的展现独立于CSS。object,video,textarea,input也是替换元素,audio和canvas在某些特定情形下为替换元素。使用CSS的content属性插入的对象是匿名替换元素。

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

对于普通元素visibility:collapse会将元素完全隐藏,不占据页面布局空间,与display:none表现相同。如果目标元素为table,visibility:collapse将table隐藏,但是会占据页面布局空间。 仅在Firefox下起作用,IE会显示元素,Chrome会将元素隐藏,但是占据空间。

CSS里content属性有什么作用?有什么应用?

css的content属性专门应用在 before/after 伪元素上,用于来插入生成内容。

可以配合自定义字体显示特殊符号。

让页面里的字体变清晰,变细用CSS怎么做?

-webkit-font-smoothing: antialiased;

specified value,computed value,used value计算方法

  • specified value,计算方法如下:
    1. 如果样式表设置了一个值,使用这个值
    2. 如果没有设置值,这个属性是继承属性,从父元素继承
    3. 如果没设置,并且不是继承属性,使用css规范指定的初始值
  • computed value: 以specified value根据规范定义的行为进行计算,通常将相对值计算为绝对值,例如em根据font-size进行计算。一些使用百分数并且需要布局来决定最终值的属性,如width,margin。百分数就直接作为computed value。line-height的无单位值也直接作为computed value。这些值将在计算used value时得到绝对值。定义值经过层叠(cascade)计算就是计算值。注意,计算值绝对不需要浏览器渲染文档(也就是计算值是在浏览器渲染文档之前产生的)。
  • used value:计算值并不依赖与文档的渲染,但是有些属性比如width:50% 必须要在渲染文档之后才能确定。因此,当浏览器渲染文档时,把计算值和它对其他元素的依赖综合起来就是使用值。对于大多数属性可以通过window.getComputedStyle获得,尺寸值单位为像素。以下属性依赖于布局,
    • background-position
    • bottom, left, right, top
    • height, width
    • margin-bottom, margin-left, margin-right, margin-top
    • min-height, min-width
    • padding-bottom, padding-left, padding-right, padding-top
    • text-indent
  • actual value 使用值已经可以合法的用来渲染了,但是某些情况下浏览器可能依然会有其他的限制,比如只能border宽度只能是整数,比如色弱模式下必须显示高对比颜色,使用值加上这些限制计算出来的就是实际值。 实际值是最终应用在元素属性上的。

CSS3有哪些新特性?

  • 新增各种CSS选择器 (: not(.input):所有 class 不是“input”的节点)
    • 圆角 (border-radius:8px)
  • 多列布局 (multi-column layout)
  • 阴影和反射(Shadow\Reflect)
    • 文字特效(text-shadow)
    • 文字渲染(text-decoration)
    • 线性渐变(gradient)
  • 变形如旋转、缩放、移动、倾斜等(transform)
  • 滤镜Filter

CSS Filter

CSS3的滤镜属性,用于渲染元素图像/背景和边界的视觉效果。

filter: none | blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url();](https://www.html5rocks.com/en/tutorials/filters/understanding-css/)

rgba()opacity的透明效果有什么不同

答案:

rgba()和opacity都能实现透明效果,但最大的不同是opacity作用于元素,以及元素内的所有内容的透明度,

而rgba()只作用于元素的颜色或其背景色。(设置rgba透明的元素的子元素不会继承透明效果!)

全屏滚动的原理是什么,用到了CSS的那些属性

利用定位和页面高度来移动单屏,可能用到的属性

overflow: hidden;
position: relative;
height: 100vh;

overflow: scroll时不能平滑滚动的问题怎么处理

大概了解了下,主要是iOS可能遇到这样的问题

-webkit-overflow-scrolling: touch;,是因为这行代码启用了硬件加速特性,所以滑动很流畅。

CSS属性区分大小写吗

不区分

为什么切换大小写后CSS不生效

因为HTML元素区分大小写

伪元素:root指向<html>

translate函数可以使元素在z轴上移动

不能


单位/比例

在CSS样式中常使用px、pt、%、em、rem,各有什么优劣,在表现上有什么区别?

在CSS中,W3C文档把尺寸单位划为为两类:相对长度单位和绝对长度单位。

  • 绝对长度单位是固定尺寸,它们采用的是物理度量单位:cm、mm、in、px、pt以及pc。

  • px与显示设备相关。对于屏幕显示,通常是一个设备像素(点)的显示。

    对于打印机和高分辨率的屏幕,一个CSS像素意味着多个设备像素,因此,每英寸的像素的数量保持在96左右。

    mm 毫米。

    cm 厘米(10毫米)。

    in 英寸(2.54厘米)。

    pt 磅(1/72 英寸)。

    pc 12 点活字 (1 pc 等于 12 点)。

  • 相对长度单位按照不同的参考元素,又可以分为字体相对单位和视窗相对单位。

    • 字体相对单位有:em、ex、ch、rem等
    • em 相对长度单位,这个单位表示元素的font-size的计算值。如果用在font-size 属性本身,它会继承父元素的font-size。
    • ex 这个单位表示元素fontx-height 。在含有“X”字母的字体中,它是该字体的小写字母的高度;对于很多字体, 1ex ≈ 0.5em。
    • ch 这一单位代表元素所用字体 font中“0”这一字形的宽度(“0”,Unicode字符U+0030)
    • lh 等于元素行高line-height的计算值
    • rlh 等于根元素行高line-height的计算值。当用于设置根元素的行高line-height或是字体大小font-size 时,该rlh指的是根元素行高line-height或字体大小font-size 的初始值
    • rem 这个单位代表根元素的 font-size 大小。当用在根元素的font-size上面时 ,它代表了它的初始值(译者注:默认的初始值是html的默认的font-size大小,比如当未在根元素上面设置font-size大小的时候,此时的1rem==1em,当设置font-size=2rem的时候,就使得页面中1rem的大小相当于html的根字体默认大小的2倍,当然此时页面中字体的大小也是html的根字体默认大小的2倍)。
    • 视窗相对单位则包含:vw、vh、vmin、vmax
    • vh 视口高度的 1/100。
    • vw 视口宽度的 1/100。
    • vmin 视口高度和宽度之间的最小值的 1/100。
    • vmax 视口高度和宽度之间的最大值的 1/100。

实际应用中,我们使用最广泛的则是em、rem、px以及百分比(%)来度量页面元素的尺寸。

  1. px:为像素单位。它是显示屏上显示的每一个小点,为显示的最小单位。它是一个绝对尺寸单位;
  2. em:它是描述相对于应用在当前元素的字体尺寸,所以它也是相对长度单位。一般浏览器字体大小默认为16px,则2em == 32px;
  3. %: 百分比,它是一个更纯粹的相对长度单位。它描述的是相对于父元素的百分比值。如50%,则为父元素的一半。

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

元素宽度与高度的百分比分别相对父元素宽/高设定等;

但元素的margin/padding百分比是相对父元素的宽度。

如果 <p>元素设置 font-size: 10rem,页面在改变大小时字体大小会变吗

不会


定位相关

请罗列出你所知道的 display 属性的全部值

如果说我知道的:

  • none
  • block
  • inline
  • inline-block
  • table
  • table-cell
  • flex
  • grid
  • inherit

我不知道的:

有很多,就不列举了9

请解释 inline 、 inline-block和block 的区别?

  • 块元素

    默认情况宽度与父元素一致,独占一行,前后块元素会换行

    可以设置宽高,内边距和外边距

  • 行内元素

    宽度与内容一致,前后没有换行符

    不能设置元素的宽高

    水平方向可以设置外边距和内边距,竖直方向不可以

  • 行内块元素

    前后没有换行符,多个行内块在一行显示

    可以设置元素宽高

请解释 relative、fixed、absolute 和 static 元素的区别

不同定位的区别。

  • static

    默认定位,按照文档流的位置来定位

  • relative 相对定位

    元素按照本来static定位的位置进行相对位移,位移值为left与top的值

    不脱离文档流,原来的占位存在

  • absolute 绝对定位

    元素脱离文档流,相对最近的非static定位父元素进行定位

  • fixed 固定定位

    元素脱离文档流,相对整个页面窗口进行定位

position的值

  • absolute :生成绝对定位的元素, 相对于最近一级的 定位不是 static 的父元素来进行定位。
  • fixed (老IE不支持)生成绝对定位的元素,通常相对于浏览器窗口或 frame 进行定位。
  • relative 生成相对定位的元素,相对于其在普通流中的位置进行定位。
  • static 默认值。没有定位,元素出现在正常的流中
  • sticky 生成粘性定位的元素,容器的位置根据正常文档流计算得出

如何确定一个元素的包含块(containing block)

  1. 根元素的包含块叫做初始包含块,在连续媒体中他的尺寸与viewport相同并且anchored at the canvas origin;对于paged media,它的尺寸等于page area。初始包含块的direction属性与根元素相同。

  2. positionrelative或者static的元素,它的包含块由最近的块级(displayblock,list-item, table)祖先元素的内容框组成

  3. 如果元素positionfixed。对于连续媒体,它的包含块为viewport;对于paged media,包含块为page area

  4. 如果元素positionabsolute,它的包含块由祖先元素中最近一个positionrelative,absolute或者fixed的元素产生,规则如下:

    • 如果祖先元素为行内元素,the containing block is the bounding box around the padding boxes of the first and the last inline boxes generated for that element.
    • 其他情况下包含块由祖先节点的padding edge组成

    如果找不到定位的祖先元素,包含块为初始包含块

absolute的containing block(容器块)计算方式跟正常流有什么不同

无论属于哪种,都要先找到其祖先元素中最近的 position 值不为 static 的元素,然后再判断: 1、若此元素为 inline 元素,则 containing block 为能够包含这个元素生成的第一个和最后一个 inline box 的 padding box (除 margin, border 外的区域) 的最小矩形; 2、否则,则由这个祖先元素的 padding box 构成。 如果都找不到,则为 initial containing block。

补充:

  1. static(默认的)/relative:简单说就是它的父元素的内容框(即去掉padding的部分)
  2. absolute: 向上找最近的定位为absolute/relative的元素
  3. fixed: 它的containing block一律为根元素(html/body),根元素也是initial containing block

请解释浮动 (Floats) 及其工作原理。

浮动使得元素脱离当前文档流,向指定方向移动直至遇到其他浮动元素或者父元素,初始是为了解决图像的文本围绕效果。现在是很多网页布局的一种方式。

position跟display、float这些特性相互叠加后会怎么样?

如果元素display:none,那么元素不被渲染,position,float不起作用

如果元素拥有position:absolute或者position:fixed属性那么元素将为绝对定位,float不起作用。

如果元素position:realative,float属性与相对定位同时生效

如果元素position:static,float属性生效

如果元素float属性不是none,元素会脱离文档流,根据float属性值来显示。有浮动,绝对定位,inline-block属性的元素,margin不会和垂直方向上的其他元素margin折叠。

display: none;visibility: hidden;的区别

联系:它们都能让元素不可见

区别:

  1. display:none会让元素完全从渲染树中消失,渲染的时候不占据任何空间;visibility: hidden不会让元素从渲染树消失,渲染师元素继续占据空间,只是内容不可见
  2. display: none是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示;visibility: hidden是继承属性,子孙节点消失由于继承了hidden,通过设置visibility: visible可以让子孙节点显式
  3. 修改常规流中元素的display通常会造成文档重排(reflow)。修改visibility属性只会造成本元素的重绘(repaint)。
  4. 屏幕阅读器不会读取display: none元素内容;会读取visibility: hidden元素内容

绝对定位元素的宽度

  • 如果绝对定位元素包裹块级元素,则其width值始终等于子元素中宽度最大者的值
  • 如果绝对定位元素包裹行内元素,则其width值最大为子元素宽度之和,最小为子元素宽度最大值,并需先求出影响width值的left区间,再用其包含块的宽度-left值来求其宽度

vertical-align属性


盒模型

请解释你对盒模型的理解,以及如何在 CSS 中告诉浏览器使用不同的盒模型来渲染你的布局。

盒模型7是CSS呈现内容样式的核心之一,包括margin-border-padding-content。MDN上标准盒模型的图示:

标准盒模型

标准盒模型下,宽高不包括padding和border,元素的背景会延伸到padding和border;外边距在同一BFC中会发生折叠。

但IE的怪异模式下,盒模型宽高会包括padding和border。

通过box-sizing能够更改用于计算元素宽度和高度的默认的 CSS 盒子模型。

  • box-sizing: content-box; 默认值,元素宽高等于内容区宽高。
  • box-sizing: border-box; 元素宽高包括padding、border和content,

请解释 * { box-sizing: border-box; } 的作用, 并且说明使用它有什么好处?

参见该文8

将所有元素的盒模型设置为border-box,能够固定实际的宽高,不根据设置的内边距和边框改变,比较适用于固定的列布局。

另一方面,也能解决和IE不一致的问题吧。

img

box-sizing属性主要用来控制元素的盒模型的解析模式。默认值是content-box。

  • content-box:让元素维持W3C的标准盒模型。元素的宽度/高度由border + padding + content的宽度/高度决定,设置width/height属性指的是content部分的宽/高
  • border-box:让元素维持IE传统盒模型(IE6以下版本和IE6~7的怪异模式)。设置width/height属性指的是border + padding + content
  • 应用场景:统一风格的表单元素 表单中有一些input元素其实还是展现的是传统IE盒模型,带有一些默认的样式,而且在不同平台或者浏览器下的表现不一,造成了表单展现的差异。此时我们可以通过box-sizing属性来构建一个风格统一的表单元素。

布局与设计

多种方法实现两列布局

左固定,右自适应

  • 左边定宽,左浮动;右边设置距离左边的宽度,即左定宽浮动+右margin

    <style>
        html, body {
          margin: 0;
          padding: 0;
        }
        .left {
          float: left;
          width: 400px;
          background: #3975b1;
        }
        .right {
          margin-left: 400px;
          background: #d66e6e;
        }
    </style>
      <main class="content">
        <div class="left">
          <p>left</p>
        </div>
        <div class="right">
          <p>right</p>
        </div>
      </main>
  • 左定宽+右绝对定位

    .content {
      position: relative;
    }
    .left {
      position: absolute;
      width: 400px;
      background: #3975b1;
    }
    .right {
      position: absolute;
      left: 400px;
      right: 0;
      background: #d66e6e;
    }

  • flex布局

    .content {
      display: flex;
      flex-direction: row;
    }
    .left {
      width: 400px;
      background: #3975b1;
    }
    .right {
      flex: 1;
      background: #d66e6e;
    }

  • 浮动+BFC

    .left {
      float: left;
      width: 400px;
      background: #3975b1;
    }
    .right {
      overflow: hidden;
      background: #d66e6e;
    }

右固定,左自适应

  • 绝对定位

    .content {
      overflow: hidden;
      position: relative;
    }
    .left {
      overflow: hidden;
      margin-right: 400px;
      background: #3975b1;
    }
    .right {
      position: absolute;
      width: 400px;
      top: 0;
      right: 0;
      background: #d66e6e;
    } 
  • flex

    .left {
      float: left;
      background: #3975b1;
    }
    .right {
      width: 400px;
      right: 0;
      background: #d66e6e;
    }

  • 浮动

    .left {
      overflow: hidden;
      margin-right: 400px;
      background: #3975b1;
    }
    .right {
      float: right;
      width: 400px;
      background: #d66e6e;
    }
      <main class="content">
        <div class="right">
          <p>right</p>
        </div>
        <div class="left">
          <p>left</p>
        </div>
      </main>

    浮动布局实现右定宽的方法有一点不好的地方在于右侧内容在html中是在左侧之前(与可视顺序不一致)

  • table布局

    .content {
      display: table;
      width: 100%;
    }
    .left {
      display: table-cell;
      background: #3975b1;
    }
    .right {
      display: table-cell;
      width: 400px;
      background: #d66e6e;
    }

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

下侧定高上侧自适应,双行布局的实现。

  • flex布局

    <style>
    html, body {
      padding: 0;
      margin: 0;
    }
    p {
      margin: 0;
    }
    /* flex layout */
    .main {
      display: flex;
      flex-direction: column;
      height: 100vh;
    }
    .up {
      flex: 1;
      background: rgb(197, 93, 93);
    }
    .down {
      height: 100px;
      background: rgb(109, 107, 206);
    }
    </style>
    <div class="main">
    <div class="up">
      <p>up</p>
    </div>
    <div class="down">
      <p>down</p>
    </div>
    </div>
  • 绝对定位

    /* absolute */
    .main {
      position: relative;
      height: 100vh;
    }
    .up {
      position: absolute;
      width: 100%;
      top: 0;
      bottom: 100px;
      background: rgb(197, 93, 93);
    }
    .down {
      position: absolute;
      width: 100%;
      bottom: 0;
      height: 100px;
      background: rgb(109, 107, 206);
    }

  • calc高度

    /* calc */
    .main {
    height: 100vh;
    }
    .up {
    height: calc(100% - 100px);
    background: rgb(197, 93, 93);
    }
    .down {
    height: 100px;
    background: rgb(109, 107, 206);
    }

CSS多列等高如何实现?

  • 利用padding-bottom|margin-bottom正负值相抵;

    设置父容器设置超出隐藏(overflow:hidden),这样子父容器的高度就还是它里面的列没有设定padding-bottom时的高度,当它里面的任 一列高度增加了,则父容器的高度被撑到里面最高那列的高度,其他比这列矮的列会用它们的padding-bottom补偿这部分高度差。

.container{
  margin:0 auto; 
  width:600px; 
  border:3px solid #00C;
  overflow:hidden;
 /*这个超出隐藏的声明在IE6里不写也是可以的*/
}
.left{
  float:left; 
  width:150px; 
  background:#B0B0B0;
  padding-bottom:2000px;
  margin-bottom:-2000px;
}
.right{
  float:left; 
  width:450px; 
  background:#6CC;
  padding-bottom:2000px;
  margin-bottom:-2000px;
}
  • 假等高列:使用背景图片,在列的父元素上使用这个背景图进行Y轴的铺放,从而实现一种等高列的假像
  • 给容器div使用单独的背景色(固定布局)(流体布局):用元素中的最大高度撑大其他的容器高度
  • 创建带边框的两列等高布局:用border-left来做,只能使用两列。
  • 使用正padding和负margin对冲实现多列布局方法:在所有列中使用正的上、下padding和负的上、下margin,并在所有列外面加上一个容器,设置overflow:hiden把溢出背景切掉
  • 使用边框和定位模拟列等高:但不能使用在多列
  • 模仿表格布局等高列效果:兼容性不好,在ie6-7无法正常运行

品字布局

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

三列布局(中间固定两边自适应宽度)

圣杯布局就是典型的三列布局

圣杯布局

<style>
    body {
      margin: 0;
      padding: 0;
      text-align: center;
      min-width: 600px;
    }
    #header, #footer {
      background: #ccc;
    }
    #footer {
      clear: both;
    }
    #container {
      padding-left: 200px;
      padding-right: 200px;
    }
    #container .column {
      height: 200px;
      float: left;
      position: relative;
    }
    #center {
      background: #6cc57b;
      width: 100%;
    }
    #left {
      width: 200px;
      margin-left: -100%;
      right: 200px;
      background: #ec532d;
    }
    #right {
      width: 200px;
      margin-right: -200px;
      background: #847ada;
    }
  </style>
<body>
  <div id="header">#header</div>
  <div id="container">
    <div id="center" class="column">#center</div>
    <div id="left" class="column">#left</div>
    <div id="right" class="column">#right</div>
  </div>
  <div id="footer">#footer</div>
</body>

其他实现方法:

  • left/right分别左右浮动,main设置左右margin

    但该方法需要html元素顺序 left/right/center

  • left/right分别左右浮动,main使用overflow:hidden触发块级格式上下文

    该方法需要html元素顺序 left/right/center

  • flex布局,left/right定宽,html元素顺序 left/main/right

  • left/right绝对定位, main设置margin,html元素顺序main/left/right

你用过栅格系统 (grid system) 吗?如果使用过,你最喜欢哪种?

栅格系统主要规范了页面的布局,对于标准化开发比较友好;有过Bootstrap和Materialize-CSS的使用经验。对喜欢哪种目前没概念。

请问你有尝试过 CSS Flexbox 或者 Grid 标准规格吗?

尝试过flex布局,了解过grid布局;

这两个布局都是CSS3引入的display属性,目前还不是全平台兼容性。

曾经引入flex解决固定底部Footer的问题。

Flex布局与Grid布局

为什么响应式设计 (responsive design) 和自适应设计 (adaptive design) 不同?

  • 自适应设计,不同设备/屏幕布局不同,但在每个布局中元素不随窗口大小的调整发生变化
  • 流动式设计,页面元素宽度会随窗口的大小而改变
  • 响应式设计,结合上两者,同时对屏幕进行自适应布局和流式布局

上下文及特殊特性

描述z-index和叠加上下文是如何形成的。

这个问题比较有名的CSS博主有篇文章比较详细1,我大概总结下:

z-index描述元素在z轴的显示顺序,指示元素如何堆叠在屏幕上,大部分元素默认值auto。当元素发生层叠的时候,其覆盖关系遵循下面2个准则:

  • 谁大谁上:在同一个层叠上下文中,较高z-index值的元素覆盖低z-index值的元素。
  • 后来居上:当元素的层叠水平一致、层叠顺序相同的时候,在DOM流中处于后面的元素会覆盖前面的元素。

由于父元素嵌套子元素,所以层叠上下文主要描述了元素所处的局部层叠结构,毕竟不同的父元素里同样z-index值的元素层叠水平是不一致的。层叠上下文分为根元素层叠上下文/定位元素z-index非auto时的层叠上下文/CSS3中的层叠上下文。

请描述 BFC(Block Formatting Context) 及其如何工作。

日常JS可能更关注些,对块级格式上下文的确不太了解,参考了这篇博文2

触发了块级格式上下文的元素可以看作是隔离的独立容器,容器里面的元素不会在布局上影响到外面的元素,并且 BFC 具有普通容器没有的一些特性,例如可以包含浮动元素,防止出现高度塌陷的问题。

块格式化上下文(block formatting context) 是页面上的一个独立的渲染区域,容器里面的子元素不会在布局上影响到外面的元素。它是决定块盒子的布局及浮动元素相互影响的一个因素。

触发 BFC 的条件如下:

  • 浮动元素,float 除 none 以外的值
  • 绝对定位元素,position(absolute,fixed)
  • display 为以下其中之一的值 inline-blocks,table-cells,table-captions
  • overflow 除了 visible 以外的值(hidden,auto,scroll)

主要有3个特性:

  • 可以阻止外边距折叠

  • 可以包含浮动元素

  • 阻止元素被浮动元素覆盖

IFC:行内格式上下文

框会从包含块的顶部开始,一个接一个地水平摆放。 摆放这些框的时候,它们在水平方向上的外边距、边框、内边距所占用的空间都会被考虑在内。在垂直方向上,这些框可能会以不同形式来对齐:它们可能会把底部或顶部对齐,也可能把其内部的文本基线对齐。能把在一行上的框都完全包含进去的一个矩形区域,被称为该行的行框。水平的margin、padding、border有效,垂直无效。不能指定宽高。 行框的宽度是由包含块和存在的浮动来决定。行框的高度由行高计算这一章所描述的规则来决定。 行框一定会高到足以容纳它所包含的全部框。然而,它也可能比它所包含的最高的框还要高(例如:这些框是以基线对齐)。当框 B 的高度小于包含它的行框时,则 B 在行框中垂直对齐的位置由’vertical-align’ 属性来决定。当几个行级框在水平方向上无法塞得进同一个行框时,它们会被分布在两个或多个垂直堆放的行框中。行框会以既没有垂直间距 也没有重叠的方式被垂直堆放起来。

通常,行框的左边紧贴其包含块的左边,而行框的右边紧贴其包含块的右边。然而,浮动框可以插在包含块边缘与行框边缘之间。因此,尽管在同一个IFC中的行框通常有同样的宽度(也就是其包含块的宽度),但它们的宽度也可能受浮动让水平可用空间减少的影响而有所改变。在同一个IFC中,行框的高度通常是变化的(例如:某一行包含了一个比较高的图片,而其它行只包含文本)。

当一行上的行级框的总宽度小于包含它们的行框的宽度,则它们在行框内的水平分布由’text-align’属性来决定。

当一个行内框的宽度超过了行框的宽度,则它会被分割成几个框,而这些框会分布在几个行框。如果此行内框不可分割(例如:单个字符、或语言指定的文字打断规则不允许在此行内框中出现打断、或该行内框受 white-space 属性为 nowrap或 pre 的影响),那么该行内框溢出该行框。

BFC的作用

1.清除内部浮动:对子元素设置浮动后,父元素会发生高度塌陷,也就是父元素的高度变为0。解决这个问题,只需要把把父元素变成一个BFC就行了。常用的办法是给父元素设置overflow:hidden。

2.上下margin重合问题,可以通过触发BFC来解决


实际应用

请问 "resetting" 和 "normalizing" CSS 之间的区别?你会如何选择,为什么?

都是解决浏览器默认样式不一致的问题

resetting重置所有样式

normalizing只是修改一些样式让不同浏览器一致,相比起来更轻量级

你会如何解决特定浏览器的样式问题?

自己可能简单粗暴使用noramlize或者reset,如果针对特定浏览器,可以检测浏览器来发送与该浏览器相关的样式文件。

列举不同的清除浮动的技巧,并指出它们各自适用的使用场景。

这篇博文3总结得非常专业。貌似CSS的每个问题都可以开一篇博文来详细分析啊,可能CSS比较需要show me the code, show me the result吧。

浮动引起的问题主要是父元素内容高度不会被撑开,导致高度塌陷。清除浮动主要两种方案:clear和BFC元素(上个问题提到的能够包含浮动元素)。

clear有几种方法

  • 直接对浮动元素的兄弟元素使用clear:both,但是这样兄弟元素的外边距会被浮动元素影响,大于浮动元素高度才能生效
  • div元素使用clear:both,但是破坏语义和结构分离的原则
  • :after伪元素,通常该方法弊端最少

BFC元素根据上一个问题有几种方法,比如overflow,父元素设置浮动或者改变display等,但父元素设置浮动会将问题传递给父元素的父元素,改变display则会破坏元素的盒子模型,所以overflow方法比较适用。

请解释 CSS sprites,以及你要如何在页面或网站中实现它。

概念:将多个小图片拼接到一个图片中。通过background-position和元素尺寸调节需要显示的背景图案。

优点:

  1. 减少HTTP请求数,极大地提高页面加载速度
  2. 增加图片信息重复度,提高压缩比,减少图片大小
  3. 更换风格方便,只需在一张或几张图片上修改颜色或样式即可实现

缺点:

  1. 图片合并麻烦
  2. 维护麻烦,修改一个图片可能需要从新布局整个图片,样式

页面导入样式时,使用link和@import有什么区别?

  • link属于XHTML标签,除了加载CSS外,还能用于定义RSS, 定义rel连接属性等作用;而@import是CSS提供的,只能用于加载CSS;
  • 页面被加载的时,link导入的样式可以并行加载,而@import会等引用的样式加载完后继续加载后部分样式;
  • link方式的样式的权重 高于@import的权重

有哪些的隐藏内容的方法 (如果同时还要保证屏幕阅读器可用呢)?

这个和图像替换的方法类似吧,隐藏内容但保证阅读器可用,需要元素可见(不能设置display:none)。

隐藏的方法包括但不限于:缩进或位置不可见/被其他内容覆盖/display:hiddenoverflow:hidden隐藏溢出的内容

  1. visibility: hidden;这个属性只是简单的隐藏某个元素,但是元素占用的空间任然存在。
  2. opacity: 0;一个CSS3属性,设置0可以使一个元素完全透明,制作出和visibility一样的效果。与visibility相比,它可以被transition和animate
  3. position: absolute;使元素脱离文档流,处于普通文档之上,给它设置一个很大的left负值定位,使元素定位在可见区域之外。
  4. display: none;元素会变得不可见,并且不会再占用文档的空间。这种方法会对屏幕阅读器不可见。
  5. transform: scale(0);将一个元素设置为无限小,这个元素将不可见。这个元素原来所在的位置将被保留。
  6. HTML5 hidden attribute;hidden属性的效果和display:none;相同,这个属性用于记录一个元素的状态
  7. height: 0; overflow: hidden;将元素在垂直方向上收缩为0,使元素消失。只要元素没有可见的边框,该技术就可以正常工作。
  8. filter: blur(0);将一个元素的模糊度设置为0,从而使这个元素“消失”在页面中。

如何为有功能限制的浏览器提供网页?

  • 提示用户开启某些功能
  • 使用Polyfill
  • 优雅降级,针对可能失效的功能采取备选方案

你会使用哪些技术和处理方法?

这个问题有些摸不着头脑啊,自由发挥?

仅指CSS的话,可以使用预处理css以及添加后缀、压缩合并等打包技术。

如何优化网页的打印样式?

这个应该也是在设备查询中优化吧。

@media print {
  ...
}

另外,在标签内也可以指定打印样式。

<link rel=“stylesheet” type="text/css" media="print" href="XXX.css">
  • 不要使用CSS背景图片,使用<img>
  • 注意像素的一致性

使用 CSS 预处理器的优缺点有哪些?

优点

  • 更像一门编程语言,扩展性好,有函数/变量/混合器
  • 可嵌套,书写更方便

缺点:

  • 需要预处理器编译成CSS
  • 门槛略高

请描述你曾经使用过的 CSS 预处理器的优缺点。

使用过sass,优缺点如上吧。

如果设计中使用了非标准的字体,你该如何去实现?

如果我自己使用,很可能就在<head>标签或者CSS中@import导入外部字体了;

但是有可能只有少数文本使用该字体,导入所有字体文件就有点浪费了

  • 用图片代替
  • 可以将使用的文本打包出自定义的Webfont,使用@font-face定义字体类别。

你在开发或生产环境中使用过哪些 CSS 框架?你觉得应该如何改善他们?

使用过Bootsrtap框架和Materialize-CSS框架。

觉得框架使用浮动实现栅格系统没有flex灵活,毕竟需要清除浮动,容易引入一些布局问题。


实际问题

你最喜欢的图片替换方法是什么,你如何选择使用。

这个也没有接触过诶;

图片替换主要是指将文字替换成图片的技术,即在html语句中使用文字,浏览器显示时用对应的图片显示。其意义在于便于做网站优化(SEO),文字才是搜索引擎寻找的主要对象4

大概查询了下方案,真的不少5

  1. 2015 H5BP替换法
<h3 class="visuallyhidden">
  CSS-Tricks
</h3>
h3.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

该方法并没有真的进行图片替换,只是将文字隐藏起来的同时对屏幕阅读器可见。图片可自行添加其他元素。

  • 2012 H5BP替换法
<h3 class="h5bp">
  CSS-Tricks
</h3>
h3.h5bp {
  border: 0;
  font: 0/0 a;
  text-shadow: none;
  color: transparent;
  background: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/t-90/test.png);
  width: 300px;
  height: 75px;
}

将字体大小设为0来隐藏文字,貌似是一个错误的语法但可以生效?

  • 2012 Scott Kellum替换法
<h3 class="skm">
  CSS-Tricks
</h3>
h3.skm {
  width: 300px;
  height: 75px;
  background: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/t-90/test.png);
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}

将文字缩进到不可见。

  • 2003 Phark替换法
<h3 class="phark">
  CSS-Tricks
</h3>
h3.phark {
  width: 300px;
  height: 75px;
  background: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/t-90/test.png);
  text-indent: -9999px;
}

同样将文字缩进到不可见。在浏览器不能显示图片时,丢失文字。

  • 2003 Fahrner替换法(FIR)
<h3 class="fir">
  <span>Fahrner Image Replacement</span>
</h3>
h3.fir {
  width: 300px;
  height: 300px;
  background: url(fir.jpg) no-repeat;
}
h3.fir span {
  display: none;
}

​ 用<span>标签的display属性把文字隐藏起来,最后指定<h1>的背景图片。

​ 优点:使用CSS而不是标记语法提供图片,更改图片只需更改CSS。

​ 缺点:需要一组不具备任何语义的<span>标签;display属性影响屏幕阅读器使用者;浏览器不能显示图片时,文字不可显示。

  • 2003 Glider/Levin 替换法
<h3 class="levin">
  <span></span>CSS-Tricks
</h3>
h3.levin {
  width: 300px;
  height: 75px;
  position: relative;
}
h3.levin span {
  background: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/t-90/test.png);
  position: absolute;
  width: 100%;
  height: 100%;
}

使用空<span>标签显示图片,覆盖文字,在不显示图像时能够显示文字;但该方法要求图片不能透明,否则会显示出文字。

如何居中div

水平垂直居中的方法

  • 行内布局

    line-height + text-align/ vertical-align + text-align

  • 块布局

    position absolute + margin auto/ position absolute + negative margin/ position absolute + translate(-50%, -50%)

  • 水平居中:给div设置一个宽度,然后添加margin:0 auto属性

    div{
      width:200px;
      margin:0 auto;
    }
  • 让绝对定位的div居中

    div {
      position: absolute;
      width: 300px;
      height: 300px;
      margin: auto;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0;
    }
  • 水平垂直居中一

    // 已知确定容器的宽高 宽500 高300
    // 设置层的外边距
    
    div {
      position: relative;		/* 相对定位或绝对定位均可 */
      width:500px;
      height:300px;
      top: 50%;
      left: 50%;
      margin: -150px 0 0 -250px;     	/* 外边距为自身宽高的一半 */
    }
  • 水平垂直居中二

     // 未知容器的宽高,利用transform属性
     div {
     	position: absolute;		/* 相对定位或绝对定位均可 */
     	top: 50%;
     	left: 50%;
     	transform: translate(-50%-50%);
     }
  • 水平垂直居中三

     // 利用 flex 布局
     // 实际使用时应考虑兼容性
    
     .container {
     	display: flex;
     	align-items: center; 		/* 垂直居中 */
     	justify-content: center;	/* 水平居中 */
     }
     .container div {
     	width: 100px;
     	height: 100px;
     }  
父容器子容器不确定宽高的块级元素,做上下居中
  • flex

    #wrap {
      display:flex;
      justify-content:center;
      align-items:center;
    }
  • tabel

    .parent {
      text-align: center;//水平居中
      display: table-cell;
      vertical-align: middle;//垂直居中
    }
    .child {
      display: inline-block;//防止块级元素宽度独占一行,内联元素可不设置
    }
  • absolute+transform 水平垂直居中

    <div class="parent">
    <div class="child">Demo</div>
    </div>
    <style>
    .parent {
      position: relative;
    }
    .child {
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
    }
    </style>
  • webkit-box

    //对父级元素设置
    position: relative;
    display: -webkit-box;
    -webkit-box-align: center;
    -webkit-box-pack: center;

CSS实现自适应正方形

  • 方案一:CSS3 vw 单位
  • 方案二:设置垂直方向的padding撑开容器
  • 方案三:利用伪元素的 margin(padding)-top 撑开容器

常见的CSS hack

  • 三角形

    demo {
      width: 0;
      height: 0;
      border-width: 20px;
      border-style: solid;
      border-color: transparent transparent red transparent;
    }

自适应长度的输入框


规范

在书写高效 CSS 时会有哪些问题需要考虑?

既然是高效能,当然要让浏览器选择效率提高,id选择效率高于类,但不能牺牲可读性。

  • 避免使用通用选择器,尽量避免使用后代选择器
  • 规范命名
  • 组件化/模块化

抽离样式模块怎么写

将通用样式/业务样式/皮肤样式及组件样式可以分别抽离出来

方便代码复用+模块化


性能

请问为何要使用 translate() 而非 absolute positioning,或反之的理由?为什么?

这个主要涉及浏览器的渲染性能12

浏览器进行页面渲染的步骤是

浏览器渲染步骤图

  • JavaScrit 实现元素的添加/删除/移动等动画
  • 样式计算 根据CSS选择器规则获取所有元素的最终样式
  • 布局 得到元素的样式后开始计算元素的位置和占据的空间大小,最终得到页面的整体布局
  • 绘制 浏览器开始绘制元素的文本、背景、边框和阴影等
  • 合成 由于页面的各部分可能被绘制到多层,由此它们需要按正确顺序绘制到屏幕上,以便正确渲染页面。

渲染的每个步骤都会影响到页面的渲染性能,但是触发的步骤越靠前,后边的步骤都要重新计算。因此,属性的赋值要尽量改变元素靠后步骤的属性,比如改变元素的颜色就要比改变布局计算量小。

也就是说,布局要在页面渲染的时候尽量一次性完成,后边的动画部分用translate()性能要优于absolute positioning。

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

加载顺序不一致,放在body后可能会出现FOUC情况。


兼容与适配

你有兼容 retina 屏幕的经历吗?如果有,在什么地方使用了何种技术?

没有。参考这篇博文11吧。

retina屏幕属于一种高像素密度的高分屏,在苹果设备上,一个独立的像素会包含几个物理像素,所以网页的像素适配不一样。

对于字体的渲染,苹果设备会使用矢量字体,不会造成像素的模糊或者失真;对于图像,就需要适配大几倍的像素图。

对于普通屏幕与retina屏幕,通过设备查询来适配。

有哪些多屏适配方案

  • media query + rem
  • flex
  • 弹性布局
  • flexiable 整体缩放(动态设置缩放系数的方式, 让layout viewport与设计图对应,极大地方便了重构,同时也避免了1px的问题)

实战

"I am awesome"的颜色

<ul class="shopping-list" id="awesome">
  <li><span>Milk</span></li>
  <li class="favorite" id="must-buy"><span class="highlight">I am awesome</span></li>
</ul>
<style>
  ul#awesome {
    color: red;
  }
  ul.shopping-list li.favorite span {
    color: blue;
  }
</style>

蓝色

<style>
 ul#awesome #must-buy {
    color: red;
 }
 .favorite span {
    color: blue!important;
 }
</style>

蓝色

<style>
  ul.shopping-list li .highlight {
    color: red;
  }
  ul.shopping-list li .highlight:nth-of-type(odd) {
    color: blue;
  }
</style>

蓝色

<style>
  #awesome .favorite:not(#awesome) .highlight {
    color: red;
  }
  #awesome .highlight:nth-of-type(1):nth-last-of-type(1) {
    color: blue;
  }
</style>

红色

#myDude元素的位置

<style>
  #myDude {
    margin-bottom: -5px;
  }
</style>
<p id="myDude">Dude</p>

#myDude后边的元素会向上5px

<style>
  #myDude {
    margin-left: -5px;
  }
</style>
<p id="myDude">Dude</p>

#myDude往左移动5px

页面加载后,浏览器会对mypic.jpg进行下载吗?

<style>
  #test2 {
    background-image: url('mypic.jpg');
    display: none;
  }
</style>
<div id="test1">
    <span id="test2"></span>
</div>
  

<style>
  #test1 {
    display: none;
  }
  #test2 {
    background-image: url('mypic.jpg');
    visibility: hidden;
  }
</style>
<div id="test1">
    <span id="test2"></span>
</div>
  

不会

chrome的字体小于12px怎么解决


CSS预处理器与后处理器

css中的函数


参考文献

[1] http://www.zhangxinxu.com/wordpress/2016/01/understand-css-stacking-context-order-z-index/

[2] http://kayosite.com/block-formatting-contexts-in-detail.html

[3] http://kayosite.com/remove-floating-style-in-detail.html

[4] https://www.cnblogs.com/wmhuang/p/image_change.html

[5] https://css-tricks.com/the-image-replacement-museum/

[6] https://developer.mozilla.org/en-US/docs/Web/SVG

[7] https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_Box_Model/Introduction_to_the_CSS_box_model

[8] https://css-tricks.com/international-box-sizing-awareness-day/

[9] https://developer.mozilla.org/en-US/docs/Web/CSS/display

[10] https://developer.mozilla.org/zh-CN/docs/Web/CSS/Specificity

[11] https://www.cnblogs.com/cench/p/5314044.html

[12] https://developers.google.com/web/fundamentals/performance/rendering/