轻松过面!大厂高频CSS基础面试题汇总

学过前端的人应该都知道CSS的重要性,所以,在前端开发的面试中,CSS的面试题会占到很大一部分的比重,而其中,基础知识又是必考项,这是体现面试者对于前端知识是否掌握好,基础是否牢固的重要证明。

今天,小职就为大家带来一些在前端开发面试中经常会出现的CSS基础面试题,看看你都掌握好了吗?赶紧查漏补缺,前端初学者也可以通过这些基础知识来加深对CSS的了解哦~

一、CSS是什么?

CSS即层叠样式表(Cascading Style Sheets),是一种用来表现HTML或XML等文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。

CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。

二、为什么需要CSS?

CSS是Web开发人员定义其创建的网页外观的一种方式,旨在允许开发人员将网站代码的内容和结构与视觉设计分开。结构和样式的分离使HTML可以执行其最初基于的更多功能-内容标记,而不必担心页面本身的设计和布局,这通常称为“外观”页面。

三、CSS集成到HTML页面的方式有哪些?

1、设置标签的style=""属性,称为内联样式;

2、在HTML的<head>标签中使用<style>标签,称为嵌入式样式;

3、创建并链接外部CSS文件,称为外部样式表。

四、css与html结合有哪些方式?

1、每个标签加一个属性法;

2、head中加style标签;

3、head中使用头标签 link。

五、CSS样式(选择器)的优先级?

!important > 行内样式 > ID选择器 > 类选择器 > 标签选择器 > 其他

六、标准的CSS的盒子模型与低版本IE的盒子模型的区别?

标准盒子模型:宽度=内容的宽度(content)+ border + padding + margin
低版本IE盒子模型:宽度=内容宽度(content+border+padding)+ margin

七、CSS三大特性是什么?

CSS 的三大特性分别是层叠性、继承性、优先级。

1.层叠性

层叠性是指相同选择器给设置相同的样式,此时一个样式就会覆盖另一个冲突的样式,层叠性主要解决样式冲突的问题。

层叠性原则:样式冲突,则遵循就近原则;样式不冲突,则不层叠。

2.继承性

CSS中的继承: 子标签会继承父标签的某些样式,如文本颜色和字号。恰当地使用继承可以简化代码,降低 CSS 样式的复杂性。

子元素可以继承父元素的样式,如text-,font-,line-这些元素开头的可以继承,以及color属性。

行高的继承性:行高可以跟单位也可以不跟单位;如果子元素没有设置行高,则会继承父元素的行高为 x;此时子元素的行高是:当前子元素的文字大小 * x;body 行高 x,这样写最大的优势就是里面子元素可以根据自己文字大小自动调整行高。

3、优先级(权重)

当同一个元素指定多个选择器,就会有优先级的产生。

八、伪类和伪元素的区别

伪类是一个以冒号作为前缀,被添加到一个选择器末尾的关键字,当你希望样式在特定状态才被呈现到指定的元素时,可以往元素的选择器后面加上对应的伪类。伪元素则用于创建一些不在文档树中的元素,并为其添加样式。

伪类和伪元素的主要区别在于,伪类是通过在元素选择器上加入伪类改变元素状态。伪元素通过对元素的操作进行对元素的改变。

九、CSS3新增伪类有哪些?

  • p:first-of-type 选择属于其父元素的首个元素;

  • p:last-of-type 选择属于其父元素的最后元素;

  • p:only-of-type 选择属于其父元素唯一的元素;

  • p:only-child 选择属于其父元素的唯一子元素;

  • p:nth-child(2) 选择属于其父元素的第二个子元素;

  • :checked 单选框或复选框被选中。

  • :enabled :disabled 表单控件的禁用状态;

十、为什么要初始化CSS样式

因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对CSS初始化往往会出现浏览器之间的页面显示差异。

十一、为什么清除浮动?如何清除?

在开发过程中,浮动元素是css中最常用的属性,浮动起来的元素会脱离标准流。如果父级盒子没有设置高度就会造成父级盒子的高度塌陷,从而影响下面盒子的正常显示。

清除方法:

1、给父级盒子添加高度

造成高度塌陷的原因就是父盒子没有高度,我们只需要给父盒子添加一个高度即可

2、额外标签法

额外标签法会在浮动元素末尾添加一个空的标签。给这个标签设置clear属性,注意这个标签必须是块级元素

3、给父级添加 overflow 属性

这个方法是向浮动元素的父级盒子添加voerflow:hidden属性,这样就可以达到清除浮动的效果

4、给父级添加after伪元素

利用after伪元素定义一个clearfix类,浮动元素的父级元素调用此类可以实现清除浮动的效果

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

这需要根据具体情况来看,正常来说,当按百分比设定一个元素的宽度时,它是相对于父容器的宽度计算的。但是,对一些表示竖向距离的属性,例如 padding-top , padding-bottom , margin-top , margin-bottom 等,当按百分比设定它们时,依据的也是父容器的宽度,而不是高度。

十三、嵌入式样式表的优缺点是什么?

1、优点:

  • 可以在一个文档中创建多种标签类型。

  • 在复杂情况下,可以使用选择器和分组方法来应用样式。

  • 无需额外下载。

2、缺点:无法控制多个文档。

十四、CSS的常用框架有哪些?

1、Bootstrap:美国Twitter公司的设计师基于HTML、CSS、JavaScript 开发的简洁、直观、强悍的前端开发框架,使得 Web 开发更加快捷。Bootstrap提供了优雅的HTML和CSS规范,它即是由动态CSS语言Less写成。

2、Layui:是一款采用自身模块规范编写的前端 UI 框架,遵循原生 HTML/CSS/JS 的书写与组织形式,门槛极低,拿来即用。其外在极简,体积轻盈,组件丰盈,非常适合界面的快速开发。

3、ElementUI:一套为开发者、设计师和产品经理准备的基于 Vue 2.0的桌面端组件库。

4、antd:是基于 Ant Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。开箱即用的高质量 React 组件,全链路开发和设计工具体系,数十个国际化语言支持。

十五、px 和 em 的区别

px全称pixel像素,是相对于屏幕分辨率而言的,它是一个绝对单位,但同时具有一定的相对性。在同一个设备上每个像素代表的物理长度是固定不变的,这点表现的是绝对性。但是在不同的设备之间每个设备像素所代表的物理长度是可以变化的,这点表现的是相对性。

em是一个相对长度单位,具体的大小需要相对于父元素计算。

十六、居中为什么要使用 transform,而不用 marginLeft/Top?

transform 属于合成属性,对合成属性进行 transition/animation 动画将会创建一个合成层,这使得被动画元素在一个独立的层中进行动画。通常情况下,浏览器会将一个层的内容先绘制进一个位图中,然后再作为纹理上传到 GPU,只要该层的内容不发生改变,就没必要进行重绘,浏览器会通过重新复合来形成一个新的帧。

top/left属于布局属性,该属性的变化会导致重排,即指对这些节点以及受这些节点影响的其他节点,进行CSS计算->布局->重绘过程,浏览器需要为整个层进行重绘并重新上传到 GPU,造成了极大的性能开销。

十七、 什么是响应式设计?响应式设计的基本原理是什么?

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

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

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

十九、什么是“渐进增强”和“平稳退化”?

渐进增强是指以最基本的可用性作为出发点,在保证站点页面在低级浏览器中的可用性和可访问性的基础之上,逐步增加功能及提高用户体验。我们日常的一些开发习惯,例如首先使用标记语言编写页面,然后通过样式表来控制页面样式等,其实都属于渐进增强的概念。

平稳退化是指先使用最新的技术面向高级浏览器构建最强的功能及用户体验,然后再针对低级浏览器的限制,逐步衰减那些无法被支持的功能及体验。在我们日常的开发中,先针对Chrome编写页面代码,然后修复IE中的异常或针对IE去除那些无法被实现的功能特色,就是一个典型的平稳退化的例子。

在HTML5与 CSS3实战中,“渐进增强”和“平稳退化”这两个概念尤其重要了,怎样保证使用不断变化的新技术来构建在主流浏览器下都具有基本可用性的站点,并针对高级浏览器进行体验提升,这些是我们在开发过程中需要明确的思路。

上面这些CSS高频考点你都掌握了吗?如果还有遗漏的地方赶紧记下来吧。作为CSS的基础,并且也是很多公司前端岗位面试的高频考点,熟记上面的内容可以帮你轻松过面试,避免因为基础知识掌握不牢固而与心仪的公司失之交臂的遗憾哦~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容