2021应届秋招前端面经(一)CSS部分
CSS
css权重 (Specificity)
- 较长的css选择器权重会大于较短的css选择器
- id选择器权重高于class选择器
- Specificity is the means by which browsers decide which CSS property values are the most relevant to an element and, therefore, will be applied. Specificity is based on the matching rules which are composed of different sorts of CSS selectors
- 官方文档中用 Specificity: 特异性 来表示一个 css selector 和其元素的相关性. 相关性越强, 即表示表示其权重最高。
- Specificity is a weight that is applied to a given CSS declaration, determined by the number of each selector type in the matching selector
- Specificity 是由 selector 中 不同 selector type 的数目决定的。
- a: 如果 css 属性声明是写在 style=“” 中的, 则数目为 1, 否则为 0
- b: id 选择器的数目
- c: class 选择器, 属性选择器(如 type=“text”), 伪类选择器(如: ::hover) 的数目
- d: 标签名(如: p, div), 伪类 (如: :before)的数目
由第一个 selector type a 的计算规则可知: 写在 html 代码 style 属性中的 css 相较写在 css 选择器中的 css 属性具有最高的优先级。
而 id selector (b) 相较 class selector (c) 有更高的优先级. 这也和我们平时的经验相吻合。
- 除了上面 Specificity 计算规则中的 css 选择器类型, 还有一些选择器如: *, +, >,:not() 等. 这些选择器并不会被计算到 css 的权重当中 。
- 有一个需要特别注意一下的选择器: :not(), 虽然它本身是不计权重的, 但是写在它里面的 css selector 是需要计算权重的。
- 如果 a,b,c,d 算完都一样,最后声明的 css selector 会生效。
- 如果我重复同样的 css selectory type, 权重会被重复计算。
按照 MDN的说法, !important 是不在 css 选择器的权重计算范围内的, 而它之所以能让 css 选择器生效是因为浏览器在遇见 !important 时会进行特殊的判断. 当多个 !important 需要进行比较时, 才会计算其权重再进行比较.
通常来说, 不提倡使用 !important. 如果你认为一定要使用, 不妨先自检一下:
- 总是先考虑使用权重更高的 css 选择器, 而不是使用 !important
- 只有当你的目的是覆盖来自第三方的 css(如: Bootstrap, normalize.css)时, 才在页面范围使用 !important
- 永远不要 在你写一个第三方插件时使用 !important
- 永远不要在全站范围使用 !important
块级元素 block:
顾名思义,该元素呈现“块”状,所以它有自己的宽度和高度,可以自定义width和height。并且独自占据一行高度(float浮动除外),一般可作为其他容器使用,可容纳块级元素和行内元素。
块级元素有以下特点:
- 每个块级元素都是独占一行。
- 元素的高度(height)、宽度(width)、行高(line-height)和边距(margin,padding)都是可以设置的。
- 元素的宽度如果不设置,默认为父元素的宽度(父元素宽度100%)
//定义地址
//定义文档中的分页区或节
//定义列表
- //定义列表中的项目