CSS常考知识点

2020-09-09  本文已影响0人  Jafeney

本章介绍一下CSS的知识点,CSS的东西很多,下面这些是比较高频的考点,希望对你有所帮助:

2.1 常用选择器

面试官:请介绍一下常用的选择器及其优先级吧(基础题)

在CSS中,选择器是一种模式,用于选择需要添加样式的元素。常用的选择器按优先级从高往低分别是:

当然,除了以上这些。给元素添加的内联样式 (例如 style="font-weight:bold") 总会覆盖外部样式表的任何样式 ,因此可看作是具有最高的优先级

面试官:复杂的项目里往往会遇到样式给覆盖的问题,解决此类问题行之有效方法有哪些呢?(拓展题)

最简单的方法是给这个样式后面增加 !important,这样该样式的声明将覆盖任何其他声明,但是使用 !important 是一个坏习惯,应该尽量避免,因为这破坏了样式表中固有的级联规则使得调试找bug变得更加困难了。当两条相互冲突的带有!important规则的声明被应用到相同的元素上时,拥有更大优先级的声明将会被采用,因此我推荐的方法有2个:

  1. 利用CSS级联属性,给该元素声明一个优先级更高的选择器,如:.example span {}span加个 .text的类: .example .text {}
  2. 增加一个或多个其他元素,使选择器变得更加具体,并获得更高的优先级,如 .example .text {} 改成 .example > div > .text {}

面试官:刚提到了!important的弊端,那我们什么时候可以使用!important呢?(发散题)

这个题目是个发散题,一般人很难答得全,其实有两种情况我们可以使用 !important

  1. 一种情况是你的网站上有一个设定了全站样式的CSS文件,同时你(或是你同事)写了一些很差的内联样式。在这种情况下,你就可以在你全局的CSS文件中写一些!important的样式来覆盖掉那些直接写在元素上的行内样式。
  2. 第二种情况是已经给某个样式加持了优先级非常高的选择器,在无法改HTML结构的情况下,可以使用 !important来做覆盖。

2.2 布局常用单位

面试官:请列举一下我们css布局常用的单位及区别(基础题)

2.3 块级和行内元素

面试官:请简单介绍一下块级元素和行内元素的区别,并分别举例5个(基础题)

块级元素与行内元素有几个关键区别:

- 格式:默认情况下,块级元素会新起一行
- 内容模型:一般块级元素可以包含行内元素和其他块级元素。这种结构上的包含继承区别可以使块级元素创建比行内元素更”大型“的结构

常见的块级元素如 div、header、footer、ul、p标签等;常见的行内元素如 span、strong、input、label、i标签等

2.4 常用定位方式

面试官:css里定位方式有哪几种,它们各有什么用途呢?(基础题)

CSS里共有5种定位方式,它们分别是:

面试官:元素设置了非static定位后可以用z-index做分层,说一下你对z-index的理解 (发散题)

CSS 中的z-index属性控制重叠元素的垂直叠加顺序,类似PS的图层概念。默认元素的z-index为0,我们可以修改z-index来控制元素的图层位置,而且z-index只能影响设置了position值的元素,我们可以设置z-index为负数去隐藏某个图层

面试官:上面提到如果要微调一个行内元素的垂直位置,会使用relative布局,除此之外还有别的方法吗?(基础题)

这个问题很好回答,CSS3提供了transform属性让我们很方便对一个元素进行缩放、旋转和平移,我们可以使用 translate(x, y)来对元素的位置进行微调。

面试官:相比较relative,为什么现在更推荐使用translate来改变位置呢?

答案是改变transformopacity不会触发浏览器重新布局(reflow)或重绘(repaint),只会触发复合(compositions)。而改变绝对定位会触发重新布局,进而触发重绘和复合。transform使浏览器为元素创建一个 GPU 图层,但改变绝对定位会使用到 CPU。 因此translate()更高效,可以缩短平滑动画的绘制时间。

2.5 常用布局方案

面试官:介绍一下你经常使用的一些布局方案吧(基础题)

常用布局方案有 静态布局浮动布局百分比流式布局inline-block水平布局flex弹性布局响应式布局rem布局等。现在最常用的是 flex弹性布局 和 rem布局。

面试官:实现垂直居中你一般有哪几种方案?(基础题)

最简单的方法是用使用 flex布局:

<div class="container">
  <div class="content">内容</div>
</div>

.container {
  display: flex;
  align-items: center;
  justify-content: center;
}

或者利用定位:

.container {
  position: relative;
}

.content {
  width: 100px;
  height: 100px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
}

或者采用BFC + transform:

.container {
  width: 500px;
  height: 500px;
  overflow: hidden; /*使容器成为一个BFC*/
}

.content {
  width: 100px;
  height: 100px;
  margin-top: 50%;
  transform: translateY(-50%);
}

2.6 层叠上下文(BFC)

面试官:正常流式布局下,我们如果给2个相邻的块级元素同时设置margin-topmargin-bottom10px,他们实际会产生多少margin呢?(基础题)

这个是日常做布局时经常会遇到的问题,答案当然是 10px,不过很多人是知其然却不知其所以然,所以就算这个答对了,面试官往往也不会“罢休”

面试官:OK,回答正确。可以继续讲一下出现这个边距折叠的原因和如何避免这个问题吗?(拓展题)

常规流布局时,盒子都是垂直排列,两者之间的间距由各自的外边距所决定,但不是二者外边距之和。在CSS当中,相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的外边距可以结合成一个单独的外边距。这种合并外边距的方式被称为折叠,并且因而所结合成的外边距称为折叠外边距。折叠的结果按照如下规则计算:

至于如何避免这个问题,就需要引出 块级格式化上下文(Block Formatting Context,BFC) 的概念,外边距折叠(Margin collapsing)只会发生在属于同一BFC的块级元素之间,因此我们只需把两个块级元素设置为单独的BFC,就能解决这个问题,最简单的方式是给两个区块设置 overflow: hidden;

面试官:OK,回答正确,不过除了解决外边距塌陷, 你知道BFC还有其他的用途吗?(发散题)

除了解决外边距塌陷,应用BFC还能让 浮动元素的容器也能被撑开 :浮动元素是会脱离文档流的(绝对定位元素会脱离文档流)。如果一个没有高度或者heightauto的容器的子元素是浮动元素,则该容器的高度是不会被撑开的。我们可以给容器加一个 overflow: hidden; 来解决这个问题:

.container {
  height: auto;
  border: 1px solid #ddd;
  overflow: hidden;   /*使容器成为一个BFC*/
}

.child {
  float: right;
  width: 200px;
  height: 100px;
  background: #f0f0f0;
}

不过现在浮动不常用了,利用BFC还有其他2个常用的用途:

拓展:BFC的触发条件

块格式化上下文(Block Formatting Context,BFC) 是Web页面的可视化CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。下面这些条件会触发BFC:

更多BFC的知识欢迎点击这个 传送门 进行查看

2.7 媒体查询

面试官:请讲一下你对媒体查询的理解以及它的作用(基础题)

媒体查询由一个可选的媒体类型和零个或多个使用媒体功能的限制了样式表范围的表达式组成,例如宽度、高度和颜色。媒体查询,添加自CSS3,允许内容的呈现针对一个特定范围的输出设备而进行裁剪,而不必改变内容本身, 非常适合web网页应对不同型号的设备而做出对应的响应适配(即响应式布局)

<!-- link元素中的CSS媒体查询 -->
<link rel="stylesheet" media="(max-width: 800px)" href="example.css" />

<!-- 样式表中的CSS媒体查询 -->
<style>
@media (max-width: 600px) {
  .facet_sidebar {
    display: none;
  }
}
</style>

2.8 盒模型

面试官:请简单介绍一下你对盒模型的理解(基础题)

当对一个文档进行布局(layout)的时候,浏览器的渲染引擎会根据标准之一的 CSS 基础框盒模型(CSS basic box model),将所有元素表示为一个个矩形的盒子(box)。CSS 决定这些盒子的大小、位置以及属性(例如颜色、背景、边框尺寸…)。盒模型由 content(内容)、padding(内边距)、border(边框)、margin(外边距)组成:

标准盒模型

2.9 伪类和伪元素

面试官:请介绍一下什么是伪类和伪元素,并介绍一下他们的区别(基础题)

他们的区别可以概括为:伪类是通过在元素选择器上加入伪类改变元素状态,而伪元素通过对元素的操作进行对元素的改变

2.10 动画与过渡

面试官:CSS动画和过渡有什么区别吗?(基础题)

总得来说,transition更加粗一点,比如过渡的速度进行了封装,可以控制是匀速改变还是贝塞尔曲线之类的。而animation提供的keyframe方法,可以手动去指定每个阶段的属性。此外animation还封装了循环次数,动画延迟等功能,配置自由且功能强大。

面试官:CSS3如何实现逐帧动画吗?(拓展题)

CSS3 可以使用 animation-timing-function 的阶梯函数 steps(number_of_steps, direction) 来实现逐帧动画的连续播放。并配合雪碧图,通过更改 background-image 的值实现帧的切换。

本文由博客一文多发平台 OpenWrite 发布!

上一篇 下一篇

猜你喜欢

热点阅读