CSS
1.CSS有哪些基本选择器?它们的权重是如何表示的?
css基本选择器有类选择器、属性选择器和ID选择器
作为标签属性的style | ID选择器 | 类名选择器 | 标签名选择器 |
---|---|---|---|
1000 | 0100 | 0010 | 0001 |
元素样式渲染时,权重高的选择器样式会覆盖权重低的选择器样式。
!important
关键字优先级最高
注意: !important
并非选择器,而是针对选择器内的单一样式设置的。当然,不同选择器内应用
!important
的权重也是不一样的。(权重越高的选择器 !important
关键字权重越高 )
2.CSS的引入方式有哪些? link
和 @import
的区别是什么?
css有三种引入方式:
- 行内式指将样式写在元素的
style
属性内 - 内嵌式是指将样式写在style元素内
- 外链式是指通过
link(@import)
标签,引入css文件内的样式
通过 link
标签引入样式与通过 @import
方法引入样式有如下区别
- 加载资源的限制
link
是XHTML标签,除了加载CSS文件外,还可以加载RSS等其他事物,如加载模板等。
@import
只能加载CSS样式
- 加载方式
如果用 link
引用CSS,在页面载入时同时加载,即同步加载
如果用 @import
引用CSS,则需要等到网页完全载入后,再加载CSS文件,即异步加载
- 兼容性
link
是XHTML的标签,没有兼容问题
@import
是在CSS2.1中提出的,不支持低版本的浏览器
- 改变样式
link
的标签是DOM元素,支持使用 JavaScript
控制DOM和修改样式
@import
是一种方法,不支持控制DOM和修改样式
3.浮动元素引起的问题和解决办法是什么?
引起的问题:
- 父元素的高度无法被撑开,影响与父元素同级的元素
- 与元素同级的非浮动元素会紧随其后(类似遮盖现象)
- 如果一个元素浮动,则该元素之前的元素也需要浮动;否则,会影响页面显示的结构(即通常所说的串行现象)。
解决办法:
-
为父元素设置固定的高度
-
为父元素设置
overflow:hidden
即可清除浮动,让父元素的高度被撑开 -
外墙法是指在父元素外面,添加 "一道墙",设置属性
clear:both
-
内墙法是指在父元素内部,浮动元素的最后面,添加"一道墙"设置属性
clear:both
-
伪元素是指为了少创建元素,对父元素添加
after
伪元素,设置属性content:"";display:block;clear:both
css.clearfix:after{ content:''; display:block; clear:both; }
4. position
的值分别是相对于哪个位置定位的?
relative
:表示相对定位,相对于自己本身所在正常文档流中的位置进行定位absolute
:表示绝对定位,相对于最近一级(从直接父级元素往上数,直到根元素)定位,相对于static
的父元素进行定位fixed
:用于生成绝对定位,相对于浏览器窗口或frame进行定位static
: 是默认值,没有定位,元素出现在正常的文档流中sticky
:是生成粘性定位的元素,容器的位置根据正常文档流计算得出
5.请说明 position:absolute
和 float
属性的异同
共同点:对内联元素设置 float
和 absolute
属性,可以让元素脱离文档流,并且可以设置其宽高。
不同点: float
仍可占据位置,不会覆盖在另一个BFC区域上,浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。 absolute
会覆盖围挡流中的其他元素,即遮盖现象。
6.CSS选择器(符)有哪些?
- id选择器
#myID
- 类选择器
.myClassName
- 标签选择器
div,p,h1
- 相邻选择器
h1+p
- 子选择器
ul>li
- 后代选择器
li a
- 通配符选择器
*
- 属性选择器
button[disabled=''true]
- 伪类选择器
a:hover 、li:nth-child
表示一种状态 - 伪元素选择器
li:before 、:after
表示文档某个部分的表现
注意: 在CSS3 规范中,为了区别伪元素和伪类,CSS3建议伪类用单冒号 ":"
,伪元素用双冒号 "::"
7.CSS有哪些样式可以继承?哪些不可以继承?
可继承:
-
跟文本相关的属性:
color、font、font-family、font-size、 font-weight、font-variant、font-style、line-height、letter-spacing、text-align、 text-indent、text-transform、white-space 以及 word-spacing。
-
列表属性:
list-style、list-style-type、 list-style-position 以及 list-style-image
-
表格的边框属性 border-collapse 和 border-spacing
不可继承: border
, padding
, margin
, width
, height
等尺寸属性
元素显示隐藏属性:visibility可以继承,diaplay:none不可以继承。
注意:与字体相关的样式通常可以继承,与尺寸相关的样式通常不能继承
8.HTML是什么?CSS是什么?JavaScript是什么?
- HTML:(HyperText Markup Language,超文本标记语言)是做网站时使用的一些文本标记标签,比如
div ,span
等 - CSS:(Cascading Style Sheet ,层叠样式表)是做网站时为美化网站而为标签添加的样式,比如
background(北京)
,color(字体颜色)
等 - JavaScript:是网站中实现前后台交互效果、网页动画效果的一种开发语言。比如鼠标单击(
click
)事件、前后台数据请求(Ajax
)等
9.为什么初始化CSS?
因为浏览器的兼容问题,不同浏览器对有些标签的默认值时不同的,如果没有初始化CSS,往往会导致页面在不同浏览器之间出现差异。
当然初始化样式有时会对SEO产生一定的影响。但是相比较起来,初始化相对重要,则我们应该在力求影响最小的情况下完成CSS初始化。
10.display有哪些值?说明它们的作用?
block
: 块状类型。默认宽度为父元素宽度,可设置宽高,换行显示。
none
:元素不会显示,已脱离文档流。
inline
:行内元素类型。默认宽度为内容宽度,不可设置宽高,同行显示。
inline-block
:指默认宽度为内容宽度,可以设置宽高,同行显示。
list-item
:指像块元素一样显示,并添加样式列表标记。
table
:指此元素会作为块级表格显示。
inherit
:指从父元素继承 display
属性的值。
11.简述块级元素和行内元素的区别
-
块级元素:独占一行,宽高可以设置,内外边距可以设置
-
行内元素:同行显示,宽高不可设置,内外边距只可以设置水平方向
-
行内块级元素:比如
<image><input>
元素等。同行显示,宽高可以设置,内外边距可以设置。
12.解释浮动及其工作原理(掘金)
浮动元素可以向左或向右移动,直到它的外边缘碰到包含元素(父元素)或另一个浮动元素的边框为止。
虽然浮动元素已不在文档流中,但是它浮动后所处的位置依然在浮动之前的水平方向上。因为浮动元素不在文档流中,所以文档流中的块元素表现的就像浮动元素不存在一样,下面的元素会填补原来的位置。有些元素会在浮动元素的下面,但是这些元素的内容并不一定会被浮动的元素遮盖。当定位内联元素时,需考虑浮动元素的边界,围绕浮动元素防止内联元素。也可以把内联元素想象成块元素忽略的元素,而内联元素会关注的元素。
什么是浮动?
通过让元素浮动,我们可以使元素在水平上左右移动,在通过 margin
属性调整位置
浮动的原理?
使当前元素脱离普通流,相当于浮动起来一样,浮动的框可以左右移动,直至它的外边缘遇到包含框或者另一个浮动框的边缘。
13.解释一下CSS Sprite,以及如何在页面或网站中使用
CSS Sprite 其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的 background-image
, background-repeat
, background-position
的组合进行背景定位, background-position
可以用数字精确的定位出背景图片的位置。
优点:当页面加载时,不是加载每一个单独的图片,而是一次加载整个组合图片。它大大减少了HTTP请求的次数,减轻服务器压力,同时缩短了悬停加载图片所需要的时间延迟,使效果更流畅,不会停顿。
缺点:做图像拼合的时候很麻烦
14.在书写高效CSS时有哪些问题需要考虑?
- 样式,从右向左解析一个选择器
- 类型选择器的速度,ID选择器最快,(*)通配符最慢。对于常用的四种类型选择器,解析速度由快到慢一次是
ID
,class
,tag
,universal
通配符 - 不要用标签限制ID选择器(如
ul#main-navigation{}
,ID已经是唯一了,不需要tag来限制,这样做会让选择器变慢 ) - 后代选择器最糟糕(换句话说,html body ul li a {}这个选择器是很低效的)
- 想清楚你的需求,再去书写 选择器
- CSS选择器(如u
nth-child
)能够漂亮的定位我们想要的元素,又能保证CSS整洁易读。然而,这些神奇的选择器会浪费很多的浏览器资源 - 我们知道ID选择器的速度最快,但是如果都用ID选择器,会降低代码的可读性和可维护性等。在大型项目中,相对于使用ID选择器提升速度,代码的可读性和可维护性带来的收益更大。
15.页面重构怎样操作?
页面重构:根据原有页面内容和结构的基础上,通过 div+css
写出符合web标准的页面结构,让页面结构更加合理化,提升用户体验,达到良好的页面效果并提升性能。
具体实现要达到以下三点:
- 功能符合用户体验,用户交互结构完整,可通过标准验证
- 代码重构:代码质量、SEO优化、页面性能、更好的语义化、浏览器兼容、CSS优化
- 充分考虑到页面在站点中的"作用和重要性",并对其进行有针对性的优化
16.内联元素可以实现浮动吗?
在CSS中,任何元素都可以实现浮动。不论浮动元素本身是何种元素,都会生成一个块级框。因此,对于内联元素,如果设置为浮动,会产生和块级框相同的效果。
17.简要描述CSS中content属性的作用
content
属性与 :before
及 :after
伪元素配合使用,用来插入生成的内容,可以在元素之前或之后放置生成的内容。可以插入文本、图像、引号,并可以结合计数器,为页面元素插入编号。
18.如何定义高度很小的容器?
因为有一个默认的行高,所以在IE6下无法定义小高度的容器
两种解决方案分别是 overflow:hidden
或 font-size:容器高度px
20.如何让超出宽度的单行文字显示为省略号?
css
{
overflow:hidden;
width:30px;
white-space:nowrap;
text-overflow:ellipsis;
}
21.多行文字超出部分显示省略号
css
.morelineEllipsis {
overflow: hidden;
width: 100px;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 3;// 设置3行
-webkit-box-orient: vertical;
}
22.如何让英文单词发生词内断行?
输入 word-warp:break-word
23.什么叫优雅降级和渐进增强?两者有什么区别?
优雅降级(graceful degradation):是指一开始就构建完整的功能,然后在针对低版本浏览器进行兼容。
渐进增强(progressive enhancement):是指针对低版本浏览器构建页面,保证最基本的功能,然后在针对高级浏览器进行效果、交互等改进并追加功能,以达到更好的用户体验。
两者的区别如下:
- 优雅降级从复杂的现状开始,并试图减少用户体验的供给。
- 渐进增强则从一个非常基础并且能够起作用的版本开始,并不断扩充,以适应未来环境的需要。
- 降级(功能衰退)意味着往回看,而渐进增强则意味着朝前看,同时保证其根基处于安全地带。
在现实工作中我们应该根据用户中浏览器占比进行选择:高版本的浏览器占比高就选择优雅降级,低版本浏览器占比高就选择渐进增强。
但实际上大部分的工作都是渐进增强的,先有一套基本的东西上线,后边再追加功能。
24.网页制作会用到哪些图片格式?
- JPG:压缩率高,文件小,最常用。
- PNG:支持无损压缩,色彩损失小,保真度高,文件稍大。
- GIF:支持动画显示,但只支持256色显示,目前已经被Flash大量取代
25.对行内元素设置 margin-top
和 margin-bottom
是否起作用?
不起作用(需要注意行内元素的替换元素(也就是行内块元素) img
, input
,它们是行内元素,但是可以设置它们的宽度和高度,并且 margin
属性也对它们其作用, margin-top
和 margin-bottom
有着类似于 inline-block
的行为 )
26.div+css
的布局较 table
布局有什么优势?
- 改版的时候更方便,只需要改动CSS文件
- 页面加载速度更快、结构清晰、页面简洁
- 表现与结构分离
- 搜索引擎优化(SEO)更友好,排名更靠前
速度和加载方式方面的区别:
<div>
:加载方式是即读即加载,遇到 <div>
没有遇到 </div>
的时候一样加载 <div>
中的内容,读多少加载多少。
<table>
:加载方式是完成后加载,遇到 <table>
后,在读到 </table>
之前, <table>
中的内容不加载。
27.谈谈你对BFC规范的理解
BFC(Block Formatting Context)指块级格式化上下文 ,即一个创建了新的BFC的盒子是独立布局的,盒子里面的子元素的样式不会影响到外面的元素。在同一个BFC中,两个毗邻的块级盒在垂直方向上(和布局方向有关系)的 margin
会发生重叠
- BFC是页面上的独立容器,内外元素互不影响
- BFC内部box在竖直方向上一个个排列
- box的纵向距离由margin决定,同一个BFC相邻的box外边距重叠
- BFC不与float box重叠
- BFC计算高度,浮动元素也参与计算
如何创建一个BFC:
- float:left/right
- overflow:hidden/auto/scroll
- display:inline-block
- position:absolute/fixed
BFC的作用:
- 避免margin重叠:同一个BFC下相邻的box外边距会产生重叠,若想避免,可以让每个box单独生成一个BFC
- 清除浮动:由于BFC计算高度的时候会计算浮动元素的高度,所以可以通过为父元素添加
overflow:hidden
生成BFC,避免浮动元素父元素的高度无法撑起的问题 - 自适应两栏布局:因为BFC不与float box重叠,所以可以通过设置左栏
float:left
,设置右栏overflow:hidden
完成两栏布局
28.谈谈你对IFC规范的理解
IFC(Inline Formitting Context)指内联格式化上下文 。IFC的线框(Line box)高度由其包含行内元素中最高的实际高度计算而来(不受竖直方向的 padding/margin
的影响)。IFC中的线框一般左右都贴近整个IFC,但是会被 float
元素扰乱。同一个IFC下的多个线框高度不同。IFC中是不可能有块级元素的,当插入块级元素时(如在 p
中插入 div
),会产生两个匿名矿,两者与 div
分隔开,即产生两个IFC,每个IFC对外表现为块级元素,与 div
垂直排列。
29.谈谈你对GFC规范的理解
GFC(GridLayout Formatting Style)指网格布局格式化上下文 ,即当把一个元素的 display
值设为 grid
的时候,此元素将会获得一个独立的渲染区域。可以通过在网格容器(grid container)上定义网格定义行和网格定义列,再往个项目上定义网格行和网格列来为每一个网格项目定义位置和空间
30.谈谈你对FFC规范的理解
FFC(Flex Formatting Style)指自适应格式化上下文 ,即 display值为 flex
或 inline-flex
的元素将会生成自适应容器。伸缩容器中的每一个子元素都是一个伸缩单元。伸缩单元可以是任意数量的。伸缩单元内和伸缩单元外的一切元素都不受影响。简单地说, Flexbox
定义了伸缩容器内伸缩单元的布局
31.访问超链接后 hover
样式就不出现的原因是什么?应该如何解决?
因为访问过的超链接样式覆盖了原有的 hover
和 active
伪类选择器样式,解决办法是将CSS属性的排列顺序改为:L->V->H->A(link,visited,hover,active)
32.什么是外边距重叠?重叠的结果是什么?
在CSS中,同一个BFC下相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的外边距可以结合成一个单独的外边距。这种合并外边距的方式成为折叠,因此而结合成的外边距称为折叠外边距。
折叠结果遵循下列计算规则
- 当两个相邻的外边距都是正数时,折叠的结果是它们两者中较大的值
- 当两个相邻的外边距都是负数时,折叠的结果是两者中绝对值较大的值
- 当两个外边距一正一负时,折叠的结果是两者相加的和
33. rgba()
和 opacity
的透明度有什么不同?
两者都能实现透明效果
opacity
作用于元素,并且可以设置元素内所有内容的透明度(具有继承性)
rgba()
只作用于元素的颜色或其背景颜色(设置rgba透明的元素的子元素不会继承透明效果)
使用 rgba
给元素的背景设置透明度的方式来替代使用 opacity
,可以解决子元素继承父元素透明度的问题
34.常用的块属性标签及其特征有哪些?
常用块标签有 div
, h1-h6
, ol
, ul
, li
, dl
, table
, p
, br
, form
。
块标签的特征有独占一行,换行显示,可以设置 宽、高,可以设置内外边距,块可以嵌套块和行标签
35.常用的行内属性标签及其特征有哪些?
行标签有 span
, a
, img
, var
, em
, strong
, textarea
, select
, option
, input
。
行标签的特征有在行内显示,内容撑开宽、高,不可以设置宽、高( img
、 input
、 textarea
等替换元素除外 ),行只能套用行标签。
36.如何避免文档流中的空白符合并现象?
空白符合并是标准文档流的特征之一,可以通过设置 white-space
修改这一特征,属性值如下:
pre
表示不会合并空白符,渲染换行符,不会自动换行,相当于pre
元素pre-wrap
表示不会合并空白符,渲染换行符,自动换行pre-line
表示合并空白符,渲染换行符,自动换行nowrap
表示合并空白符,不会渲染换行符,不会自动换行normal
表示默认值,按照文档流特点渲染,合并空白符,不会渲染换行符,自动换行。
37.CSS中,自适应的单位有哪些?
- 百分比:
%
- 相对于视口宽度的单位:
vw
- 相对于视口高度的单位:
vh
- 相对于视口宽度或高度(取决于哪个小)的单位:
vm
- 相对于当前元素字体大小或者父元素字体大小的单位:
em
- 相对于根元素字体大小的单位:
rem
38.什么是 FOUC
?如何避免 FOUC
?
FOUC
即无样式内容闪烁(Flash Of Unstyled Content),是在IE下通过 @import
导入css文件引起的。
IE会首先加载整个HTML文档的DOM,然后再导入外部的css文件。因此,在页面DOM加载完成到css导入完成之间,有一段时间页面上的内容是没有样式的,这段时间的长短跟网速和电脑速度都有关系。
解决方法:在<head>
之间加入一个<link>
标签来导入css文件。
39.CSS中类(class)和ID的区别
- 书写上的差别:class名用 "."号开头来定义,id名用"#"号开头来定义
- 优先级不同(权重不同)
- 调用上的区别:在同一个html网页页面中class是可以被多次调用的(在不同地方)。而id名作为标签的身份则是唯一的,id在页面中只能出现一次。在js脚本中经常会用到id来修改一个标签的属性
- id作为元素的标签,用于区分不同结构和内容,而class作为一个样式,它可以应用到任何结构和内容上
- 在布局思路上,一般坚持这样的原则:id是先确定页面的结构和内容,然后再为它定义样式;而class相反,它先定义好一类样式,然后在页面中根据需要把类样式应用到不同的元素和内容上面
- 在实际应用时,class更多地被应用到文字版块或页面修饰等等,而id更多地被用来实现宏伟布局和设计包含块或包含块的样式
一般原则:类应该应用于概念上相似的元素,这些元素可以出现在同一页面上多个位置,而ID应该应用于不同的唯一的元素。
40.如何解决特定浏览器的样式问题?
- 主张向前兼容,不考虑向后兼容
- 根据产品的用户群中各大浏览器,来考虑需要兼容的浏览器
- 把浏览器分为两类,一类历史遗留浏览器,一类是现代浏览器,然后根据这个分类开发两个版本的网站,然后自己定义哪些浏览器是历史遗留浏览器,历史遗留版浏览器,使用历史遗留页面,通过通告栏告知用户使用现代浏览器,功能更全面,提供好的用户体验。
- 直接在用户的浏览器不能兼容的时候,提示用户至少什么版本的IE和火狐 谷歌浏览器才能支持
- 项目开始前就得需要确认兼容支持的最低版本是什么,设计一个对应的兼容方案
41.使用CSS预处理器的优缺点有哪些?
缺点 :简单来说CSS预处理器语言较CSS玩法变得更高级了,但同时降低了自己对最终代码的控制力。更致命的是提高了门槛,首先是上手门槛,其次是维护门槛,再来是团队整体水平和规范的门槛。这也造成了初学学习成本的昂贵。
优点 :用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标生成文件,然后开发者就只要使用这种语言进行编码工作。通俗的说,CSS预处理器用一种专门的编程语言,进行Web页面样式设计,然后再编译成正常的CSS文件,以供项目使用。CSS预处理器为CSS增加一些编程的特性,无需考虑浏览器的兼容性问题,例如你可以在CSS中使用变量、简单的逻辑程序、函数等等在编程语言中的一些基本特性,可以让你的CSS更加简洁、适应性更强、可读性更佳,更易于代码的维护等诸多好处。
42.请解释浏览器是如何判断元素是否匹配某个CSS选择器?
浏览器解析css选择器的规则是从右向左的,这样会提高查找选择器所对应的元素的效率。
HTML 经过解析生成 DOM Tree(这个我们比较熟悉);而在 CSS 解析完毕后,需要将解析的结果与 DOM Tree 的内容一起进行分析建立一棵 Render Tree,最终用来进行绘图。
Render Tree 中的元素(WebKit 中称为「renderers」,Firefox 下为「frames」)与 DOM 元素相对应,但非一一对应:一个 DOM 元素可能会对应多个 renderer,如文本折行后,不同的「行」会成为 render tree 种不同的 renderer。也有的 DOM 元素被 Render Tree 完全无视,比如 display:none 的元素。
在建立 Render Tree 时(WebKit 中的「Attachment」过程),浏览器就要为每个 DOM Tree 中的元素根据 CSS 的解析结果(Style Rules)来确定生成怎样的 renderer。对于每个 DOM 元素,必须在所有 Style Rules 中找到符合的 selector 并将对应的规则进行合并。选择器的「解析」实际是在这里执行的,在遍历 DOM Tree 时,从 Style Rules 中去寻找对应的 selector。
因为所有样式规则可能数量很大,而且绝大多数不会匹配到当前的 DOM 元素(因为数量很大所以一般会建立规则索引树),所以有一个快速的方法来判断「这个 selector 不匹配当前元素」就是极其重要的。
如果正向解析,例如「div div p em」,我们首先就要检查当前元素到 html 的整条路径,找到最上层的 div,再往下找,如果遇到不匹配就必须回到最上层那个 div,往下再去匹配选择器中的第一个 div,回溯若干次才能确定匹配与否,效率很低。
逆向匹配则不同,如果当前的 DOM 元素是 div,而不是 selector 最后的 em,那只要一步就能排除。只有在匹配时,才会不断向上找父节点进行验证。 但因为匹配的情况远远低于不匹配的情况,所以逆向匹配带来的优势是巨大的。
同时我们也能够看出,在选择器结尾加上「*」就大大降低了这种优势,这也就是很多优化原则提到的尽量避免在选择器末尾添加通配符的原因
43.flex实现均匀分布
里边div数量不固定实现等宽、水平均匀分布。
css
{
display: flex;
justify-content: space-around; /*space-between左右两侧靠边位置没有空隙*/
flex-wrap: wrap; /*换行*/
}
垂直均匀分布
css
display: flex;
flex-direction: column;
justify-content: space-evenly; /*水平方向均匀分布*/
align-items: center;/*水平居中*/
flex-wrap: wrap;
44.px,%,em,rem,vw/vh的区别
- px:绝对单位,无论在哪一种情况下都是一样的
- %:相对父元素的宽度比例
- em:相对当前元素的font-size,当用em设置font-size时是相对于父元素的font-size
- rem:相对根元素的font-size 常用于根据屏幕不同的宽度使用media设置html的font-size,从而根据不同的屏幕显示不同的字体。
- vw:相对屏幕宽度的1%
- vh:相对屏幕高度的1%
- vmin:vw和vh中最小的一个
- vmax:vw和vh中最大的一个
45. background-size中的cover与contain的区别
background-size中的cover与contain都是都是将图片以相同宽高比缩放以适应整个容器的宽高。
不同的是在no-repeat情况下,如果容器宽高比与图片宽高比不同:
- cover会缩放至图片能够铺满整个容器,可能会有部分图片区域被裁剪,
- 而contain则是图片会缩放至整个图片都能显示完全,但是容器可能会有留白。
在repeat情况下:
- cover:与上述相同;
- contain:容器内至少有一张完整的图,容器留白区域则平铺背景图,铺不下的再裁掉。
ps:这个就是设置大小的,不是位置
46. z-index从父原则
什么是从父原则:
- 子元素在与父辈元素比较的时候,用父辈的 z-index 去比较
- 在与同级元素比较的时候,才有自己的 z-index 去比较
什么情况下会出现从父原则:
- 父元素通过fixed absolute relative定位的元素, 子元素也是fixed absolute relative定位的元素。
- 在父元素上设置了z-index
- 跟父元素同级的元素也是通过fixed absolute relative定位的元素,并且设定了z-index
47.简要介绍⼀下, 你在项⽬中, 如何管理各个元素的 z-index
制定使⽤z-index的规范,⽐如 popover,modal,colorpicker 之类的组件,按照组件特性指定其层级的⾼低规范。另外业务布局中如果⽤到了z-index,尽量控制其层级为较低的规范内,如布局中的z-index尽量使⽤1xx,弹出层类的组件使⽤2xx等。
全局维护⼀个获取z-index的⽅法,每次调⽤时数值递增1:
js
/* 思路:
我们可以把 DOM 中的所有元素集合起来,
然后转化成一个数组,
然后我们遍历这个数组,把所有元素的 z-index 值提取出来,然后就形成了一个纯数字的数组,
最后从中取到最大值,就是当前页面中的最大的 z-index 值了。
*/
function getZIndex(){
return [...document.all].reduce((r, e) => Math.max(r, +window.getComputedStyle(e).zIndex || 0), 0)
}
在element-ui中,可以统一使用PopupManager管理
js
import { PopupManager } from 'element-ui/lib/utils/popup'
PopupManager.nextZIndex()
48.简要介绍⼀下, 你如何在项⽬中管理样式的? 如何避免不同⻚⾯ / 模块中, 样式的互相影响 ?
-
使用BEM规则,通过区分模块和元素来进⾏样式命名。
-
通过 css modules 将css进⾏分模块管理。
jsimport buttons from "./buttons.css"; import padding from "./padding.css"; element.innerHTML = `<div class="${buttons.red} ${padding.large}">`;
49.%都是相对于谁的
相对于父级元素宽高
width
,height
,margin
,padding
,text-indent
... 等
相对于父级定位元素宽高
top
,left
,right
,bottom
相对于自身宽高
border-radius
,translate
,transform-origin
,zoom,background-size
相对于自身字体大小
line-height
相对于继承字体大小
font-size
50.display:none 和visibility:hidden的区别
- display:none会将元素从DOM树中卸载,visibility不会,所以visibility只是元素不可见,但是任然占据位置,display则不占据位置
- display:none会引起回流,visibility引起重绘
- display不具有继承性,但是由于在DOM中卸载,所以子元素也不可见,visibility具有继承性,子元素可以通过visibility设置visible显示
CSS3
1.css3有哪些新特性?
- 圆角(border-radius)
- 阴影(box-shadow)
- 对文字加特效(text-shadow)
- 线性渐变(gradient)
- keyframes定义动画
- 变换(transform)
- 更多的CSS选择器
- 多背景设置
- 色彩模式,如rgba
- 伪元素
::selection
- 媒体查询
- 多栏布局
- 图片边框(border-image)
2.CSS3新增伪类有哪些?
p:first-of-type
:选择属于其父元素的首个<p>
元素的每个<p>
元素。p:last-of-type
:选择属于其父元素的最后一个<p>
元素的每个<p>
元素。p:only-of-type
:选择属于其父元素的唯一<p>
元素的每个<p>
元素。p:only-child
:选择属于其父元素的唯一子元素的每个<p>
元素。p:nth-child(2)
:选择属于其父元素的第二个子元素的每个<p>
元素。:enabled:disabled
:控制表单控件的禁用状态。:checked
:单选框或复选框被选中。
3. :first-of-type
和 :first-child
的区别是什么?
:first-child
匹配的是父元素的第一个子元素,可以说是结构上的第一个子元素。
first-of-type
匹配的是该类型的第一个元素,类型就是指冒号前面匹配到的元素。并不限制是第一个子元素,只要是该类型元素的第一个即可,这些元素的范围都属于同一级,也就是同辈。
javascript
eg:
<div>
<p></p>
<span></span>
</div>
p:first-child
匹配到的 p元素,因为p元素是div的第一个子元素
span:first-child
匹配不到span元素,因为span是div的第二个子元素
p:first-of-type
匹配到p元素,因为p是div所有为p的子元素中的第一个。
span:first-of-type
匹配到span元素,因为span是div多有span的子元素中的第一个。
4.介绍下 box-sizing
属性
该属性主要用来控制元素盒模型的解析模式。默认值是 content-box
content-box
让元素维持W3C的标准盒模型。元素的宽度/高度由 border+padding+content
的宽度/高度决定,设置width/height属性指的是指定 content部分的宽度/高度。
border-box
让元素维持IE传统盒模型(IE以下版本和IE6、IE7的怪异模式)。设置width/height属性指的是指定 border+padding+content
的宽度/高度。
标准浏览器下,按照W3C规范解析盒模型。一旦修改了元素的边框或内距,就会影响元素的盒子尺寸,就不得不重新计算元素的盒子尺寸,从而影响整个页面的布局。
5.CSS3动画的优缺点是什么?
优点:
- 在性能上会稍微好一点,浏览器会对CSS3的动画做一些优化。
- 代码相对简单
缺点:
- 在动画控制上不够灵活
- 兼容性不好
- 部分动画功能无法实现
6. background-origin
和 background-clip
的区别是什么?
background-origin
定义的是背景位置( background-position
)的起始点;
background-clip
是对背景(图片和背景色)的切割。
7. box-shadow
的溢出问题以及解决方案
子容器加了box-shadow
在父容器中可能存在溢出:
html
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8" />
<title></title>
</head>
<style>
.outer {
width: 200px;
height: 200px;
background: #ffffff;
border: 1px solid #000000;
border-radius: 10px;
/* overflow: hidden; */
}
.inner {
width: 100px;
height: 100px;
margin: 50px auto;
background: #eeeeee;
box-shadow: 75px 75px red;
}
</style>
<body>
<div class="outer">
<div class="inner">这里是inner元素</div>
这里是innter兄弟元素
</div>
</body>
</html>
效果:
可以给父元素outer
添加:overflow: hidden;
但是相应的超出范围的元素也会被隐藏
如果想超出范围的元素被展示,可以使用overflow: scroll;
8.box-shadow
阴影被覆盖问题
上下相连的块级元素如果下方的元素有设置背景就会把上方元素的下阴影给覆盖掉:
html
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8" />
<title></title>
</head>
<style>
.outer {
width: 200px;
height: 200px;
background: #ffffff;
border: 1px solid #000000;
border-radius: 10px;
overflow: scroll;
}
.inner {
width: 100px;
height: 100px;
background: #eeeeee;
box-shadow: 75px 75px red;
}
.inner1 {
background-color: yellow;
}
</style>
<body>
<div class="outer">
<div class="inner">这里是inner元素</div>
<div class="inner1">这里是innter兄弟元素</div>
</div>
</body>
</html>
解决方案1:.inner
添加transform: translate3d(0, 0, 0);
解决方案2:.inner
使用相对定位position:relative
可以把阴影显示出来
css常见布局
两栏布局
html
<div class="left">
<h1>Left Side</h1>
<p>我是左侧栏</p>
</div>
<div class="right">
<h1>Right Side</h1>
<p>我是右侧栏</p>
</div>
浮动定位法:float + margin-left
css
.left{
width: 200px;
background-color: antiquewhite;
float: left;
}
.right{
background-color: cornflowerblue;
/* 等于左侧的宽度 */
margin-left: 200px;
}
绝对定位法:absolute + margin-left
css
.left {
width: 200px;
background-color: antiquewhite;
position: absolute;
background-color: yellow;
}
.right {
background-color: cornflowerblue;
/* 等于左侧的宽度 */
margin-left: 200px;
}
margin负值法
html
<div class="aside"></div>
<div class="main">
<div class="content"></div>
</div>
css
.aside {
width: 300px;
height: 100px;
background: darkcyan;
margin-right: -100%;
float: left;
}
.main {
width: 100%;
float: right;
}
.content {
margin-left: 300px;
height: 100px;
background: salmon;
}
flex
html
<div class="box"> //关键
<div class="left">
<h1>Left Side</h1>
<p>我是左侧栏</p>
</div>
<div class="right">
<h1>Right Side</h1>
<p>我是右侧栏</p>
</div>
</div>
css
.box{
display:flex;
}
.left{
width: 200px;
background-color: antiquewhite;
}
.right{
flex: 1; //关键
background-color: cornflowerblue;
}
- 当 flex 取值为一个非负数字,则该数字为 flex-grow 值,flex-shrink 取 1,flex-basis 取 0%
- 当 flex 取值为一个长度或百分比,则视为 flex-basis 值,flex-grow 取 1,flex-shrink 取 1,(注意 0% 是一个百分比而不是一个非负数字)
- 当 flex 取值为两个非负数字,则分别视为 flex-grow 和 flex-shrink 的值,flex-basis 取 0%
- 当 flex 取值为一个非负数字和一个长度或百分比,则分别视为 flex-grow 和 flex-basis 的值,flex-shrink 取 1
三栏布局
浮动定位法:float + margin
左栏左浮右栏右浮,中间不设宽度用左右margin值撑开距离,且布局中中间栏放最后
html
<div class="left">
<h1>Left</h1>
</div>
<div class="right">
<h1>Right</h1>
</div>
<!--middle 在左右的后边-->
<div class="middle">
<h1>Middle</h1>
</div>
css
.left{
width: 200px;
height: 300px;
background-color: darksalmon;
float: left;
}
.middle{
// 不设置宽度
height: 300px;
background-color: darkseagreen;
margin: 0 200px;
}
.right{
width: 200px;
height: 300px;
background-color: firebrick;
float: right;
}
绝对定位法:absolute + margin
左右两栏绝对定位,分别固定到页面的左右两侧,中间栏不设宽度,用左右margin撑开距离。
html
<div class="left">左栏</div>
<div class="middle">中间栏</div>
<div class="right">右栏</div>
css
.left {
width: 200px;
height: 300px;
background-color: #DC698A;
position: absolute;
left: 0;
top: 0;
}
.middle {
height: 300px;
background-color: #8CB08B;
margin: 0 200px;
}
.right {
width: 200px;
height: 300px;
background-color: #3EACDD;
position: absolute;
right: 0;
top: 0;
}
flex
html
<div class="box">
<div class="left">左边</div>
<div class="middle">中间</div>
<div class="right">右边</div>
</div>
css
.box{
display: flex;
}
.left{
background-color: lightcoral;
width: 200px;
height: 300px;
}
.right{
background-color: lightseagreen;
width: 200px;
height: 300px;
}
.middle{
background-color: mediumorchid;
flex: 1 ;
}
水平居中
行内元素水平居中
html
<p class="inLine">块级元素中的文字居中</p>
<div class="inLine">
<span>行内元素的水平居中需要将text-align加入到父级块元素上</span>
</div>
<style>
.inLine{
text-align: center;
}
</style>
定宽块状元素水平居中
html
<div class="blockHaveWidth">定宽块状元素水平居中</div>
<style>
.blockHaveWidth{
border:solid 1px black;
width:200px;
text-align: center;
margin: 0 auto;
}
</style>
不定宽块状元素水平居中
- 改变块状元素的display属性为inline, 然后给父级设置 text-aline:center 来实现水平居中, 这种方法的缺点是不能再给元素设置宽高了
html
<div class="father">
<div class="son">不定宽块状元素水平居中</div>
</div>
<style>
.father {
text-align: center;
}
.son{
display: inline;
}
</style>
- 利用绝对定位,让元素向右偏移50%,然后再向左偏移自身的50%
html
<div class="noWidthBlock">不定宽块状元素水平居中</div>
<style>
.noWidthBlock {
position: absolute;
left: 50%;
transform: translateX(-50%);
}
</style>
- flex
html
<div class="box">
<div class="inner">不定宽块状元素水平居中</div>
</div>
<style>
.box {
display: flex;
}
.inner{
margin: 20px auto;
}
<!--或者-->
.box {
display: flex;
justify-content: center;
align-items: center;
}
</style>
- 利用CSS3的fit-content配合左右margin为auto实现水平居中方法
html
<div class="son">不定宽块状元素水平居中</div>
<style>
.son{
width: fit-content;
margin-left: auto;
margin-right: auto;
}
</style>
垂直居中
relative+absolute+margin-top(负值) 已知高度
html
<div class="parent">
<div class="child">
这里被我垂直居中了。
</div>
</div>
<style>
.parent {
height: 500px;
border: 1px solid red;
position: relative;
}
.child {
border: 1px solid green;
width: 300px;
position: absolute;
background: red;
top: 50%;
/* left: 50%; */
height: 100px;
/* margin-left: -150px; */
margin-top: -50px;
}
</style>
relative+absolute+margin-top(负值) 未知高度
html
<div class="parent">
<div class="child">
这里被我垂直居中了。
</div>
</div>
<style>
.parent {
height: 600px;
border: 1px solid red;
position: relative;
}
.child {
border: 1px solid green;
position: absolute;
background: red;
top: 50%;
transform: translate(-50% 0);
}
</style>
flex
html
<div class="parent">
<div class="child">
这里被我垂直居中了。
</div>
</div>
<style>
.parent {
height: 600px;
border: 1px solid red;
display: flex;
align-items: center;
}
.child {
border: 1px solid green;
height: 200px;
}
</style>
水平垂直居中
绝对定位元素的居中
html
<div class="center-vertical"></div>
<style>
.center-vertical {
width: 100px;
height: 100px;
background: orange;
position: absolute;
top: 50%;
left: 50%;
margin-top: -50px;
/*高度的一半*/
margin-left: -50px;
/*宽度的一半*/
}
</style>
缺点:需要提前知道元素的尺寸。如果不知道元素尺寸,这个时候就需要JS获取了。
CSS3.0的兴起,使这个问题有了更好的解决方法,就是使用 transform 代替 margin 。
transform 中 translate 偏移的百分比是相对于自身大小而说的。
html
<div class="center-vertical">水平竖直居中</div>
<style>
.center-vertical {
background: orange;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50% ,-50%);
}
</style>
优点:无论绝对定位元素的尺寸是多少,它都是水平垂直居中显示的。
缺点:就是兼容性问题。
margin:auto;实现绝对定位元素居中
html
<div class="center-vertical">水平竖直居中</div>
<style>
.center-vertical {
width: 100px;
height: 100px;
background-color: aqua;
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
margin: auto;
}
</style>
相对定位
html
<div class="center-vertical">水平竖直居中</div>
<style>
html,body{
width: 100%;
height: 100%;
margin: 0;
padding: 0;
}
.center-vertical {
width: 300px;
height: 300px;
background-color: aqua;
margin: 0 auto;
position: absolute;
top: 50%;
transform: translateY(-50%);
}
<!--或者-->
.center-vertical {
width: 300px;
height: 300px;
background-color: yellow;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
</style>
flex
html
<div class="parent">
<div class="center-vertical">水平竖直居中</div>
</div>
<style>
html,body{
width: 100%;
height: 100%;
margin: 0;
padding: 0;
}
.parent{
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.center-vertical {
background-color: aqua;
}