前端CSS知识点

1,介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同的?

有两种, IE 盒子模型、W3C 盒子模型; 

盒模型: 内容(content)、填充(padding)、边界(margin)、 边框(border);

区  别: IE的content部分把 border 和 padding计算了进去; 


在CSS3中引入了box-sizing属性, 它可以允许改变默认的CSS盒模型对元素宽高的计算方式.

共包括两个选项:

content-box:标准盒模型,CSS定义的宽高只包含content的宽高

border-box:IE盒模型,CSS定义的宽高包括了content,padding和border

5,如何居中div?



2,CSS选择符有哪些?哪些属性可以继承?

id选择器( # myid)

类选择器(.myclassname)

标签选择器(div, h1, p)

相邻选择器(h1 + p)

子选择器(ul > li)

后代选择器(li a)

通配符选择器( * ) 

属性选择器(a[rel = "external"])

伪类选择器(a:hover, li:nth-child)

可继承的样式: font-size font-family color, UL LI DL DD DT;

不可继承的样式:border padding margin width height ;


3,CSS优先级算法如何计算?

*   优先级就近原则,同权重情况下样式定义最近者为准; 

*   载入样式以最后载入的定位为准; 

优先级为:

!important >  id > class > tag 

important 比 内联优先级高 


4,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>元素。 


:after          在元素之前添加内容,也可以用来做清除浮动。 

:before         在元素之后添加内容 

:enabled       

:disabled       控制表单控件的禁用状态。 

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

6,display有哪些值?说明他们的作用。

block              象块类型元素一样显示。

none               缺省值。象行内元素类型一样显示。

inline-block   象行内元素一样显示,但其内容象块类型元素一样显示。

list-item         象块类型元素一样显示,并添加样式列表标记。

table               此元素会作为块级表格来显示

inherit            规定应该从父元素继承 display 属性的值 


7,position的值relative和absolute定位原点是?

absolute  生成绝对定位的元素,相对于值不为 static的第一个父元素进行定位。 

fixed (老IE不支持) 生成绝对定位的元素,相对于浏览器窗口进行定位。 

relative  生成相对定位的元素,相对于其正常位置进行定位。 

static        默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right z-index 声明)。 

inherit      规定从父元素继承 position 属性的值。 


8,CSS3有哪些新特性?

新增各种CSS选择器  (: not(.input):所有 class 不是“input”的节点) 

圆角           (border-radius:8px) 

多列布局        (multi-column layout) 

阴影和反射        (Shadow\Reflect) 

文字特效      (text-shadow、) 

文字渲染      (Text-decoration) 

线性渐变      (gradient) 

旋转          (transform) 

增加了旋转,缩放,定位,倾斜,动画,多背景

transform:\scale(0.85,0.90)\ translate(0px,-30px)\ skew(-9deg,0deg)\Animation:


9,用纯CSS创建一个三角形的原理是什么?

把上、左、右三条边隐藏掉(颜色设为 transparent)

#demo {

        width: 0;

        height: 0;

        border-width: 20px;

        border-style: solid;

        border-color: transparent transparent red transparent;

}


10,一个满屏  字布局 如何设计?

简单的方式:

上面的div宽100%,

下面的两个div分别宽50%,

然后用float或者inline使其不换行即可



11,li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?

行框的排列会受到中间空白(回车\空格)等的影响,因为空格也属于字符,这些空白也会被应用样式,占据空间,所以会有间隔,把字符大小设为0,就没有空格了。


12,为什么要初始化CSS样式。

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

- 当然,初始化样式会对SEO有一定的影响,但鱼和熊掌不可兼得,但力求影响最小的情况下初始化。 

最简单的初始化方法: * {padding: 0; margin: 0;} (强烈不建议) 


淘宝的样式初始化代码:

                  body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, fieldset, legend, button, input, textarea, th, td { margin:0; padding:0; } 

                  body, button, input, select, textarea { font:12px/1.5tahoma, arial, \5b8b\4f53; } 

                  h1, h2, h3, h4, h5, h6{ font-size:100%; } 

                  address, cite, dfn, em, var { font-style:normal; } 

                  code, kbd, pre, samp { font-family:couriernew, courier, monospace; } 

                  small{ font-size:12px; } 

                  ul, ol { list-style:none; } 

                  a { text-decoration:none; } 

                  a:hover { text-decoration:underline; } 

                  sup { vertical-align:text-top; } 

                  sub{ vertical-align:text-bottom; } 

                  legend { color:#000; } 

                  fieldset, img { border:0; } 

                  button, input, select, textarea { font-size:100%; } 

                  table { border-collapse:collapse; border-spacing:0; } 


13,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 


14,对BFC规范(块级格式化上下文:block formatting context)的理解?

(W3C CSS 2.1 规范中的一个概念,它是一个独立容器,决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用。) 

 一个页面是由很多个 Box 组成的,元素的类型和 display 属性,决定了这个 Box 的类型。 


不同类型的 Box,会参与不同的 Formatting Context(决定如何渲染文档的容器),因此Box内的元素会以不同的方式渲染,也就是说BFC内部的元素和外部的元素不会互相影响。

                  创建规则: 

                  根元素 

                  浮动元素(float不是none) 

                  绝对定位元素(position取值为absolute或fixed) 

                  display取值为inline-block,table-cell, table-caption,flex, inline-flex之一的元素 

                  overflow不是visible的元素 

                  作用: 

                  可以包含浮动元素 

                  不被浮动元素覆盖 

                  阻止父子元素的margin折叠 


15,css定义的权重

以下是权重的规则:标签的权重为1,class的权重为10,id的权重为100,以下例子是演示各种定义的权重值:

                  /*权重为1*/            div{} 

                  /*权重为10*/          .class1{} 

                  /*权重为100*/       #id1{} 

                  /*权重为100+1=101*/         #id1 div{} 

                  /*权重为10+1=11*/              .class1 div{} 

                  /*权重为10+10+1=21*/      .class1 .class2 div{} 

如果权重相同,则最后定义的样式会起作用,但是应该避免这种情况出现


16,请解释一下为什么会出现浮动和什么时候需要清除浮动?清除浮动的方式

浮动元素脱离文档流,不占据空间。浮动元素碰到包含它的边框或者浮动元素的边框停留。

1.使用空标签清除浮动。

这种方法是在所有浮动标签后面添加一个空标签 定义css clear:both. 弊端就是增加了无意义标签。 

2.使用overflow。

给包含浮动元素的父标签添加css属性 overflow:auto; zoom:1; zoom:1用于兼容IE6。

3.使用after伪对象清除浮动。

该方法只适用于非IE浏览器。具体写法可参照以下示例。使用中需注意以下几点。一、该方法中必须为需要清除浮动元素的伪对象中设置 height:0,否则该元素会比实际高出若干像素;


16,浮动元素引起的问题和解决办法?

浮动元素引起的问题:

(1)父元素的高度无法被撑开,影响与父元素同级的元素

(2)与浮动元素同级的非浮动元素(内联元素)会跟随其后

(3)若非第一个元素浮动,则该元素之前的元素也需要浮动,否则会影响页面显示的结构

解决方法:

使用CSS中的clear:both;属性来清除元素的浮动可解决2、3问题,对于问题1,添加如下样式,给父元素添加clearfix样式:

.clearfix:after{content: ".";display: block;height: 0;clear: both;visibility: hidden;}

.clearfix{display: inline-block;} /* for IE/Mac */


清除浮动的几种方法:

1,额外标签法,<div style="clear:both;"></div>(缺点:不过这个办法会增加额外的标签使HTML结构看起来不够简洁。)

2,使用after伪类

#parent:after{

        content:".";             height:0; visibility:hidden;                      display:block;         clear:both; 

 }

3,浮动外部元素

4,设置overflow为hidden或者auto


17,移动端的布局用过媒体查询吗?

css的媒体查询允许通过@media标签为特定媒体的浏览器设定样式,其中包含众多筛选,功能强大。


18,使用 CSS 预处理器吗?喜欢那个?             

SASS (SASS、LESS没有本质区别,只因为团队前端都是用的SASS),可以使用sass和less对css做模块化开发,定制样式的组件


19,CSS优化、提高性能的方法有哪些?

将样式表放到页面顶部

不使用CSS表达式

不使用@import

不使用IE的Filter


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

是的,元素的百分比设置一般是根据父级元素的宽高决定的,如果父级元素没有宽高百分比是不起作用的


21,什么是响应式设计?响应式设计的基本原理是什么?

响应式设计就是为了实现根据不同设备环境自动响应及调整网页布局的一种设计方案

基本原理就是利用css的媒体查询功能根据不同屏幕的大小,向下兼容设备、移动优先,达到响应的效果


22,::before 和 :after中双冒号和单冒号 有什么区别?解释一下这2个伪元素的作用。 

双冒号是在当前规范中引入的,用于区分伪类和伪元素。但是伪类兼容现存样式,浏览器需要同时支持旧的伪类,比如:first-line、:first-letter、:before、:after等。

对于CSS2之前已有的伪元素,比如:before和:after,单冒号和双冒号的写法::before和::after作用是一样的。

如果只需要兼容webkit、firefox、opera等浏览器,建议对于伪元素采用双冒号的写法,如果不得不兼容IE浏览器,还是用CSS2的单冒号写法比较安全。


23,display:inline-block 什么时候会显示间隙? 

移除空格、使用margin负值、使用font-size:0、letter-spacing、word-spacing


24,png、jpg、gif 这些图片格式解释一下,分别什么时候用? 

 GIF: 8位像素,256色                    无损压缩                  支持简单动画         支持boolean透明    适合简单动画 

JPEG:颜色限于256          有损压缩                  可控制压缩质量                       不支持透明              适合照片 

PNG:有PNG8和truecolor PNG    PNG8类似GIF颜色上限为256,文件小,支持alpha透明度,无动画、适合图标、背景、按钮 


25,是CSS 预处理器 / 后处理器? 

- 预处理器例如:LESS、Sass、Stylus,用来预编译Sass或less,增强了css代码的复用性,还有层级、mixin、变量、循环、函数等,具有很方便的UI组件模块化开发能力,极大的提高工作效率。 


- 后处理器例如:PostCSS,通常被视为在完成的样式表中根据CSS规范处理CSS,让其更有效;目前最常做的是给CSS属性添加浏览器私有前缀,实现跨浏览器兼容性的问题。 


26,css sprite是什么,有什么优缺点。

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

优点:

减少HTTP请求数,极大地提高页面加载速度

增加图片信息重复度,提高压缩比,减少图片大小

更换风格方便,只需在一张或几张图片上修改颜色或样式即可实现

缺点:

图片合并麻烦

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

png图片本身大小会超过jpg,解决办法,尽量吧小的图片转成baseurl, 再把精灵图压缩


27,你用过栅格系统吗?

现在大部分UI框架都内置有删格化系统,常用bootstrap中的,bootstap它提供了一套响应式,移动优先的流式栅格系统(grid system),将屏幕分成12列来实现响应式的。它的实现原理非常简单,Media Query加上float布局,也研究过bootstrap的源码,在这个过程中也对预处理器有了更深的体会,删格系统这块在bootstrap中sass源码使用的循环生成,less使用的递归生成,我自己也单独封装过一个删格系统


28,渐进增强和优雅降级

渐进增强 :针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

优雅降级 :一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。


29,什么是 FOUC(无样式内容闪烁)?你如何来避免 FOUC?

FOUC - Flash Of Unstyled Content 文档样式闪烁 

<style type="text/css" media="all">@import "../fouc.css";</style>

而引用CSS文件的@import就是造成这个问题的罪魁祸首。IE会先加载整个HTML文档的DOM,然后再去导入外部的CSS文件,因此,在页面DOM加载完成到CSS导入完成中间会有一段时间页面上的内容是没有样式的,这段时间的长短跟网速,电脑速度都有关系。 


解决方法简单的出奇,只要在<head>之间加入一个<link>或者<script>元素就可以了。


30,display: none;与visibility: hidden;的区别

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

区别:

display:none;会让元素完全从渲染树中消失,渲染的时候不占据任何空间;visibility: hidden;不会让元素从渲染树消失,渲染师元素继续占据空间,只是内容不可见

display: none;是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示;visibility: hidden;是继承属性,子孙节点消失由于继承了hidden,通过设置visibility: visible;可以让子孙节点显式

修改常规流中元素的display通常会造成文档重排。修改visibility属性只会造成本元素的重绘。

读屏器不会读取display: none;元素内容;会读取visibility: hidden;元素内容

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