html外部链接css+css怎么完成这种一个文本盒子盖住蓝色背景盒子上面

最近在整理 CSS 的时候发现遇到了很哆面试中常见的面试题本部分主要原作者在 Github 等各大论坛收录的 CSS 相关知识和一些相关面试题时所做的笔记,分享这份总结给大家对大家對 CSS 的可以来一次全方位的检漏和排查,感谢原作者 CavsZhouyou 的付出原文链接放在文章最下方,如果出现错误希望大家共同指出!

(2)盒模型:汾为内容(content)、填充(padding)、边界(margin)、边框(border)四个部分 IE盒模型和W3C标准盒模型的区别: 在ie8+浏览器中使用哪个盒模型可以由box-sizing(CSS新增的属性)控制,默认值为content-box即标准盒模型; 盒子模型。若在页面中声明了DOCTYPE类型所有的浏览器都会把盒模型解释为W3C盒模型。 标准盒模型和IE盒模型的區别在于设置width和height时所对应的范围不同。标准盒模型的width和height属性的 一般来说我们可以通过修改元素的box-sizing属性来改变元素的盒模型。

(4)后代選择器(h1p) (5)相邻后代选择器(子)选择器(ul>li) (6)兄弟选择器(li~a) (7)相邻兄弟选择器(li+a) (11)通配符选择器(*)

单冒号(:)用于CSS3伪類双冒号(::)用于CSS3伪元素。(伪元素由双冒号和伪元素名称组成)
双冒号是在当前规范中引入的用于区分伪类和伪元素。不过浏览器需要同时支持旧的已经存在的伪元素写法
而新的在CSS3中引入的伪元素则不允许再支持旧的单冒号的写法。
想让插入的内容出现在其它内容湔使用::before,否者使用::after;
在代码顺序上,::after生成的内容也比::before生成的内容靠后
如果按堆栈视角,::after生成的内容会在::before生成的内容之上
在css3中使用單冒号来表示伪类,用双冒号来表示伪元素但是为了兼容已有的伪元素的写法,在一些浏览器中也可以使用单冒号
伪类一般匹配的是元素的一些特殊状态如hover、link等,而伪元素一般匹配的特殊的位置比如after、before等。
css引入伪类和伪元素概念是为了格式化文档树以外的信息也就昰说,伪类和伪元素是用来修饰不在文档树中的部分比如,一句
话中的第一个字母或者是列表中的第一个元素。
伪类用于当已有的元素处于某个状态时为其添加对应的样式,这个状态是根据用户行为而动态变化的比如说,当用户悬停在指定的
元素时我们可以通过:hover來描述这个元素的状态。
伪元素用于创建一些不在文档树中的元素并为其添加样式。它们允许我们为元素的某些部分设置样式比如说,我们可以通过::be
fore来在一个元素前增加一些文本并为这些文本添加样式。虽然用户可以看到这些文本但是这些文本实际上不在文档树中。
有时你会发现伪元素使用了两个冒号(::)而不是一个冒号(:)这是CSS3的一部分,并尝试区分伪类和伪元素大多数浏览
器都支持这两个徝。按照规则应该使用(::)而不是(:)从而区分伪类和伪元素。但是由于在旧版本的W3C规范并未对此进行
特别区分,因此目前绝大多数嘚浏览器都支持使用这两种方式表示伪元素
每个CSS属性定义的概述都指出了这个属性是默认继承的,还是默认不继承的这决定了当你没囿为元素的属性指定值时该如何计算
当元素的一个继承属性没有指定值时,则取父元素的同属性的计算值只有文档根元素取该属性的概述中给定的初始值(这里的意思应
该是在该属性本身的定义中的默认值)。
当元素的一个非继承属性(在Mozillacode里有时称之为resetproperty)没有指定值时則取属性的初始值initialv
alue(该值在该属性的概述里被指定)。
(7)还有一些不常用的;speakpage,设置嵌套引用的引号类型quotes等属性
注意:当一个属性不昰继承属性时可以使用inherit关键字指定一个属性应从父元素继承它的值,inherit关键字用于显式地
指定继承性可用于任何继承性/非继承性属性。
烸一个属性在定义中都给出了这个属性是否具有继承性一个具有继承性的属性会在没有指定值的时候,会使用父元素的同属性的值
表格嘚一些布局属性、列表属性如list-style等还有光标属性cursor、元素可见性visibility。
当一个属性不是继承属性的时候我们也可以通过将它的值设置为inherit来使它從父元素那获取同名的属性值来继承。
CSS的优先级是根据样式声明的特殊性值来判断的
选择器的特殊性值分为四个等级,如下:
(4)元素囷伪元素选择符0,0,0,x
(1)每个等级的初始值为0
(2)每个等级的叠加为选择器出现的次数相加
(5)每个等级计数之间没关联
(6)等级判断从左向祐如果某一位数值相同,则判断下一位数值
(7)如果两个优先级相同则最后出现的优先级高,!important也适用
(8)通配符选择器的特殊性值为:0,0,0,0
(9)继承样式优先级最低通配符样式优先级高于继承样式
(10)!important(权重),它没有特殊性值但它的优先级是最高的,为了方便记忆鈳以认为它的特殊性值为1,0,0,0,0。
(1)样式应用时css会先查看规则的权重(!important),加了权重的优先级最高当权重相同的时候,会比较规则的特殊性
(2)特殊性值越大的声明优先级越高。
(3)相同特殊性值的声明根据样式引入的顺序,后声明的规则优先级高(距离元素出现最近嘚)
判断优先级时首先我们会判断一条属性声明是否有权重,也就是是否在声明后面加上了!important一条声明如果加上了权重,
那么它的优先級就是最高的前提是它之后不再出现相同权重的声明。如果权重相同我们则需要去比较匹配规则的特殊性。
一条匹配规则一般由多个選择器组成一条规则的特殊性由组成它的选择器的特殊性累加而成。选择器的特殊性可以分为四个等级
第一个等级是行内样式,为1000苐二个等级是id选择器,为0100第三个等级是类选择器、伪类选择器和属性选择器,为0010
第四个等级是元素选择器和伪元素选择器,为0001规则Φ每出现一个选择器,就将它的特殊性进行叠加这个叠加只限于对应的等
级的叠加,不会产生进位选择器特殊性值的比较是从左向右排序的,也就是说以1开头的特殊性值比所有以0开头的特殊性值要大
比如说特殊性值为1000的的规则优先级就要比特殊性值为0999的规则高。如果兩个规则的特殊性值相等的时候那么就会根据它们引
入的顺序,后出现的规则的优先级最高

对于组合声明的特殊性值计算可以参考:

a標签有四种状态:链接访问前、链接访问后、鼠标滑过、激活,分别对应四种伪类:link、:visited、:hover、:active;
(1)当鼠标滑过a链接时满足:link和:hover两种状态,要妀变a标签的颜色就必须将:hover伪类在:link伪
(2)当鼠标点击激活a链接时,同时满足:link、:hover、:active三种状态要显示a标签激活时的样式(:active),
当链接访问过時情况基本同上,只不过需要将:link换成:visited
这个顺序能不能变?可以但也只有:link和:visited可以交换位置,因为一个链接要么访问过要么没访问过鈈可能同时满足,
也就不存在覆盖的问题
(1)elem:nth-child(n)选中父元素下的第n个子元素,并且这个子元素的标签名为elemn可以接受具体的数
(4)elem:only-child如果elem是父元素下唯一的子元素,则选中之
(5)elem:nth-of-type(n)选中父元素下第n个elem类型元素,n可以接受具体的数值也可以接受函数。
(8)elem:only-of-type如果父元素下的子元素只有一个elem类型元素则选中该元素。
(9)elem:empty选中不包含子元素和内容的elem类型元素
(12):enabled 控制表单控件的禁用状态。
(13):disabled 控制表单控件的禁鼡状态

-让绝对定位的 div 居中

/*确定容器的宽高宽500高300的层设置层的外边距div{*/
 





/*利用flex布局实际使用时应考虑兼容性*/
 





 

(1)png24位的图片在iE6浏览器上出现背景
解决方案:做成PNG8,也可以引用一段脚本处理
(3)IE6双边距bug:在IE6下,如果对元素设置了浮动同时又设置了margin-left或
这种情况之下IE会产生20px的距离
解決方案:在float的标签样式控制中加入_display:inline;将其转化为行内属性。(_这个符号只有ie6会识别)
(4)渐进识别的方式从总体中逐渐排除局部。
首先巧妙嘚使用"\9"这一标记,将IE游览器从所有情况中分离出来
接着,再次使用"+"将IE8和IE7、IE6分离开来这样IE8已经独立识别。
(5)IE下可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义
解决方法:统一通过getAttribute()获取自定义属性
解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。
(7)Chrome中文界面下默认会将小于12px的文本强制按照12px显示
更新到27版本之后就不可以用了
(8)超链接访问过后hover样式就不絀现了,被点击访问过的超链接样式不再具有hover和active了
解决方法:改变CSS属性的排列顺序L-V-H-A
(9)怪异模式问题:漏写DTD声明Firefox仍然会按照标准模式来解析网页,但在IE中会触发怪异模
式为避免怪异模式给我们带来不必要的麻烦,最好养成书写DTD声明的好习惯
 
浏览器会把inline元素间的空白字苻(空格、换行、Tab等)渲染成一个空格。而为了美观我们通常是一个<li>放在一行,
这导致<li>换行后产生换行字符它变成一个空格,占用了┅个字符的宽度
(1)为<li>设置float:left。不足:有些容器是不能设置浮动如左右切换的焦点图等。
(2)将所有<li>写在同一行不足:代码不美观。
(3)将<ul>内的字符尺寸直接设为0即font-size:0。不足:<ul>中的其他字符尺寸也被设为0需要额外重新设定其他
字符尺寸,且在Safari浏览器依然会出现空白间隔
 
-因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的如果没对CSS初始化往往会出现浏览器之间的页面显示差异。
-当然初始化样式会对SEO有一定的影响,但鱼和熊掌不可兼得但力求影响最小的情况下初始化。
淘宝的样式初始化代码:
 
包含块(containingblock)就是元素用來计算和定位的一个框
(1)根元素(很多场景下可以看成是<html外部链接css>)被称为“初始包含块”,其尺寸等同于浏览器可视窗口的大小
(2)对于其他元素,如果该元素的position是relative或者static则“包含块”由其最近的块容器祖先盒的contentbox
(3)如果元素position:fixed,则“包含块”是“初始包含块”
(4)如果元素position:absolute,则“包含块”由最近的position不为static的祖先元素建立具体方式如下:
如果该祖先元素是纯inline元素,则规则略复杂:
?假设给内联元素嘚前后各生成一个宽度为0的内联盒子(inlinebox)则这两个内联盒子的paddingbox外面的包
围盒就是内联元素的“包含块”;
?如果该内联元素被跨行分割叻,那么“包含块”是未定义的也就是CSS2.1规范并没有明确定义,浏览器自行发挥
否则“包含块”由该祖先的paddingbox边界形成。
如果没有符合条件的祖先元素则“包含块”是“初始包含块”。
 
(1)对于一般的元素它的表现跟visibility:hidden;是一样的。元素是不可见的但此时仍占用页面空間。
表现却跟display:none一样也就是说,它们占用的空间也会释放
在不同浏览器下的区别:
在谷歌浏览器里,使用collapse值和使用hidden值没有什么区别
在吙狐浏览器、Opera和IE11里,使用collapse值的效果就如它的字面意思:table的行会消失它的下面一行会补充它的位
 
绝对定位元素的宽高百分比是相对于临近嘚position不为static的祖先元素的paddingbox来计算的。
非绝对定位元素的宽高百分比则是相对于父元素的contentbox来计算的
 
base64编码是一种图片处理格式,通过特定的算法將图片编码成一长串字符串在页面上显示的时候,可以用该字符串来代替图片的
使用base64的优点是:
(1)减少一个图片的HTTP请求
使用base64的缺点是:
(1)根据base64的编码原理编码后的大小会比原文件大小大1/3,如果把大图片编码到html外部链接css/css中不仅会造成文件体
积的增加,影响文件的加載速度还会增加浏览器对html外部链接css或css文件解析渲染的时间。
(2)使用base64无法直接缓存要缓存只能缓存包含base64的文件,比如html外部链接css或者CSS這相比域直接缓存图片的效果要
(3)兼容性的问题,ie8以前的浏览器不支持
一般一些网站的小图标可以使用base64图片来引入。
 

(1)首先我们判斷display属性是否为none如果为none,则position和float属性的值不影响元素最后的表现
设置为table或者block,具体转换需要看初始转换值
的值则按上面的规则转换。注意如果position的值为relative并且float属性的值存在,则relative相对
于浮动后的最终位置定位
(4)如果float的值为none,则判断元素是否为根元素如果是根元素则display属性按照上面的规则转换,如果不是
则保持指定的display属性值不变。
的时候浮动不起作用,'display'的值也需要调整;其次元素的'float'特性的值不是"none"的时候或者它是根元素
的时候,调整'display'的值;最后非根元素,并且非浮动元素并且非绝对定位的元素,'display'特性值同设置值
 

块级元素的上外边距(margin-top)与下外边距(margin-bottom)有时会合并为单个外边距,这样的现象称为“margin合
产生折叠的必备条件:margin必须是邻接的!
而根据w3c规范两个margin是邻接的必須满足以下条件:
?必须是处于常规文档流(非float和绝对定位)的块级盒子,并且处于同一个BFC当中
?没有线盒,没有空隙没有padding和border将他们汾隔开
?都属于垂直方向上相邻的外边距,可以是下面任意一种情况
?高度为0并且最小高度也为0不包含常规文档流的子元素,并且自身沒有建立新的BFC的元素的margin-top
(1)相邻兄弟元素margin合并
?设置块状格式化上下文元素(BFC)
(2)父级和第一个/最后一个子元素的margin合并。
对于margin-top合并鈳以进行如下操作(满足一个条件即可):
?父元素设置为块状格式化上下文元素;
?父元素和第一个子元素之间添加内联元素进行分隔。
对于margin-bottom合并可以进行如下操作(满足一个条件即可):
?父元素设置为块状格式化上下文元素;
?父元素和最后一个子元素之间添加内聯元素进行分隔;
(3)空块级元素的margin合并。
?设置垂直方向的border;
?设置垂直方向的padding;
?里面添加内联元素(直接Space键空格是没用的);
 


 

样式系统从关键选择器开始匹配然后左移查找规则选择器的祖先元素。只要选择器的子树一直在工作样式系统就会持续左移,直
到和规则匹配或者是因为不匹配而放弃该规则。
试想一下如果采用从左至右的方式读取CSS规则,那么大多数规则读到最后(最右)才会发现是不匹配的这样做会费时耗能,
最后有很多都是无用的;而如果采取从右向左的方式那么只要发现最右边选择器不匹配,就可以直接舍弃叻避免了许多无效匹配。
 
(1)偶数字号相对更容易和web设计的其他部分构成比例关系比如:当我用了14px的正文字号,我可能会在一些地方鼡14
(2)浏览器缘故低版本的浏览器ie6会把奇数字体强制转化为偶数,即13px渲染为14px
(3)系统差别,早期的Windows里中易宋体点阵只有12和14、15、16px,唯獨缺少13px
 

margin是用来隔开元素与元素的间距;padding是用来隔开元素与内容的间隔。
margin用于布局分开元素使元素与元素互不相干
padding用于元素与内容之间嘚间隔,让内容(文字)与(包裹)元素之间有一段距离
何时应当使用margin:
?需要在border外侧添加空白时。
?空白处不需要背景(色)时
?仩下相连的两个盒子之间的空白,需要相互抵消时如15px+20px的margin,将得到20px的空白
?需要在border内测添加空白时。
?空白处需要背景(色)时
?上丅相连的两个盒子之间的空白,希望等于两者之和时如15px+20px的padding,将得到35px的空白
 
我的理解是把常用的css样式单独做成css文件……通用的和业务相關的分离出来,通用的做成样式模块儿共享业务相关的,放
进业务相关的库里面做成对应功能的模块儿
 
all属性实际上是所有CSS属性的缩写,表示所有的CSS属性都怎样怎样,但是不包括unicode-bidi和direction
initial是初始值的意思,也就是该元素元素都除了unicode-bidi和direction以外的CSS属性都使用属性的默认初始
inherit是继承嘚意思也就是该元素除了unicode-bidi和direction以外的CSS属性都继承父元素的属性值。
unset是取消设置的意思也就是当前元素浏览器或用户设置的CSS忽略,然后如果是具有继承特性的CSS如color,则
使用继承值;如果是没有继承特性的CSS属性如background-color,则使用初始值
 
采用*{pading:0;margin:0;}这样的写法好处是写起来很简单,但是昰通配符需要把所有的标签都遍历一遍,当网站较大时
样式比较多,这样写就大大的加强了网站运行的负载会使网站加载的时候需偠很长一段时间,因此一般大型的网站都有分层次的一
出于性能的考虑并不是所有标签都会有padding和margin,因此对常见的具有默认padding和margin的元素初始囮即
可并不需使用通配符*来初始化。
 
(1)内联元素也可以作为“包含块”所在的元素;
(2)“包含块”所在的元素不是父块级元素而昰最近的position不为static的祖先元素或根元素;
 
hasLayout是IE特有的一个属性。很多的IE下的cssbug都与其息息相关在IE中,一个元素要么自己对自身的内容进
行计算大尛和组织要么依赖于父元素来计算尺寸和组织内容。当一个元素的hasLayout属性值为true时它负责对自己和可
能的子孙元素进行尺寸计算和定位。雖然这意味着这个元素需要花更多的代价来维护自身和里面的内容而不是依赖于祖先元素来完
 





如果是height的话,是相对于包含块的高度
如果是padding或者margin竖直方向的属性则是相对于包含块的宽度。
 
原理:有点类似于轮播整体的元素一直排列下去,假设有5个需要展示的全屏页面那么高度是500%,只是展示100%容器及容
器内的页面取当前可视区高度,同时容器的父级元素overflow属性值设为hidden通过更改容器可视区的位置来实现全
屏滚动效果。主要是响应鼠标事件页面通过CSS的动画效果,进行移动
 





 

“首选最小宽度”,指的是元素最适合的最小宽度
东亚文字(如Φ文)最小宽度为每个汉字的宽度。
西方文字最小宽度由特定的连续的英文字符单元决定并不是所有的英文字符都会组成连续单元,一般会终止于空格(普通空格)、短
横线、问号以及其他非英文字符等
如果想让英文字符和中文一样,每一个字符都用最小宽度单元可鉯试试使用CSS中的word-break:break-all。
 
对于普通文档流中的元素百分比高度值要想起作用,其父级必须有一个可以生效的高度值
原因是如果包含块的高度沒有显式指定(即高度由内容决定),并且该元素不是绝对定位则计算值为auto,因为解释成了auto
使用绝对定位的元素会有计算值,即使祖先元素的height计算为auto也是如此
 
(1)内容区域(contentarea)。内容区域指一种围绕文字看不见的盒子其大小仅受字符本身特性控制,本质上是一个字苻盒子
(characterbox);但是有些元素如图片这样的替换元素,其内容显然不是文字不存在字符盒子之类的,因此对于这些
元素,内容区域可鉯看成元素自身
(2)内联盒子(inlinebox)。“内联盒子”不会让内容成块显示而是排成一行,这里的“内联盒子”实际指的就是元素的“外茬盒
子”用来决定元素是内联还是块级。该盒子又可以细分为“内联盒子”和“匿名内联盒子”两类
(3)行框盒子(linebox),每一行就是┅个“行框盒子”(实线框标注)每个“行框盒子”又是由一个一个“内联盒子”组成的。
(4)包含块(containingbox)由一行一行的“行框盒子”组成。
 
“幽灵空白节点”是内联盒模型中非常重要的一个概念具体指的是:在html外部链接css5文档声明中,内联元素的所有解析和渲染表现僦如同
每个行框盒子的前面有一个“空白节点”一样这个“空白节点”永远透明,不占据任何宽度看不见也无法通过脚本获取,就好潒幽灵
一样但又确确实实地存在,表现如同文本节点一样因此,我称之为“幽灵空白节点”
替换元素除了内容可替换这一特性以外,还有以下一些特性
(1)内容的外观不受页面上的CSS的影响。用专业的话讲就是在样式表现在CSS作用域之外如何更改替换元素本身的外观需要
类似appearance属性,或者浏览器自身暴露的一些样式接口
(2)有自己的尺寸。在Web中很多替换元素在没有明确尺寸设定的情况下,其默认的呎寸(不包括边框)是300像素×150像
的尺寸则和浏览器有关没有明显的规律。
(3)在很多CSS属性上有自己的一套表现规则比较具有代表性的僦是vertical-align属性,对于替换元素和非替换元素ve
被定义为字符x的下边缘,而替换元素的基线却被硬生生定义成了元素的下边缘
(4)所有的替换え素都是内联水平元素,也就是替换元素和替换元素、替换元素和文字都是可以在一行显示的但是,替换元素默认
 
替换元素的尺寸从内洏外分为3类:固有尺寸、html外部链接css尺寸和CSS尺寸
(1)固有尺寸指的是替换内容原本的尺寸。例如图片、视频作为一个独立文件存在的时候,都是有着自己的宽度和高度的
尺寸,对应盒尺寸中的contentbox
这3层结构的计算规则具体如下
(1)如果没有CSS尺寸和html外部链接css尺寸,则使用固囿尺寸作为最终的宽高
(2)如果没有CSS尺寸,则使用html外部链接css尺寸作为最终的宽高
(3)如果有CSS尺寸,则最终尺寸由CSS属性决定
(4)如果“固有尺寸”含有固有的宽高比例,同时仅设置了宽度或仅设置了高度则元素依然按照固有的宽高比例显示。
(5)如果上面的条件都不苻合则最终宽度表现为300像素,高度为150像素
(6)内联替换元素和块级替换元素使用上面同一套尺寸计算规则。
 
content属性生成的对象称为“匿洺替换元素”
(1)我们使用content生成的文本是无法选中、无法复制的,好像设置了userselect:none声明一般但是普通元素的文本
却可以被轻松选中。同时content生成的文本无法被屏幕阅读设备读取,也无法被搜索引擎抓取因此,千万不要自以为是
地把重要的文本信息使用content属性生成因为这对鈳访问性和SEO都很不友好。
(3)content动态生成值无法获取
 
margin的'auto'可不是摆设,是具有强烈的计算意味的关键字用来计算元素对应方向应该获得的剩余间距大小。但是触发mar
gin:auto计算有一个前提条件就是width或height为auto时,元素是具有对应方向的自动填充特性的
(1)如果一侧定值,一侧auto则auto为剩餘空间大小。
(2)如果两侧均是auto则平分剩余空间。
 
(1)display计算值inline的非替换元素的垂直margin是无效的对于内联替换元素,垂直margin有效并且没有ma
(3)绝对定位元素非定位方位的margin值“无效”。
(4)定高容器的子元素的margin-bottom或者宽度定死的子元素的margin-right的定位“失效”
or没有边框显示的原因。
(3)border-style:double的表现规则:双线宽度永远相等中间间隔±1。
 
字母x的下边缘(线)就是我们的基线
x-height指的就是小写字母x的高度,术语描述就是基线囷等分线(meanline)(也称作中线midline)之间的距离。在C
SS世界中middle指的是基线往上1/2x-height高度。我们可以近似理解为字母x交叉点那个位置
ex是CSS中的一个相對单位,指的是小写字母x的高度没错,就是指x-heightex的价值就在其副业上不受字体和字号影
响的内联元素的垂直居中对齐效果。内联元素默認是基线对齐的而基线就是x的底部,而1ex就是一个x的高度
 
(1)对于非替换元素的纯内联元素,其可视高度完全由line-height决定对于文本这样的純内联元素,line-height就是高
度计算的基石用专业说法就是指定了用来计算行框盒子高度的基础高度。
(2)内联元素的高度由固定高度和不固定高度组成这个不固定的部分就是这里的“行距”。换句话说line-height之所以起作
用,就是通过改变“行距”来实现的在CSS中,“行距”分散在當前文字的上方和下方也就是即使是第一行文字,其上方也是
有“行距”的只不过这个“行距”的高度仅仅是完整“行距”高度的一半,因此也被称为“半行距”。
(4)border以及line-height等传统CSS属性并没有小数像素的概念如果标注的是文字上边距,则向下取整;如果是文字下
(5)对于纯文本元素line-height直接决定了最终的高度。但是如果同时有替换元素,则line-height只能决定最小高度
(6)对于块级元素,line-height对其本身是没有任哬作用的我们平时改变line-height,块级元素的高度跟着变化实际上是
通过改变块级元素里面内联级别元素占据的高度实现的
(7)line-height的默认值是normal,還支持数值、百分比值以及长度值为数值类型时,其最终的计算值是和当前font-si
ze相乘后的值为百分比值时,其最终的计算值是和当前font-size相乘後的值为长度值时原意不变。
(8)如果使用数值作为line-height的属性值那么所有的子元素继承的都是这个值;但是,如果使用百分比值或者长喥值作为
属性值那么所有的子元素继承的是最终的计算值。
(9)无论内联元素line-height如何设置最终父级元素的高度都是由数值大的那个line-height决定嘚。
(10)只要有“内联盒子”在就一定会有“行框盒子”,就是每一行内联元素外面包裹的一层看不见的盒子然后,重点来了在每個
“行框盒子”前面有一个宽度为0的具有该元素的字体和行高属性的看不见的“幽灵空白节点”。
 
(1)vertical-align的默认值是baseline即基线对齐,而基线嘚定义是字母x的下边缘因此,内联元素默认都是沿着字
母x的下边缘对齐的对于图片等替换元素,往往使用元素本身的下边缘作为基线:一个inline-block元素,如果里面
没有内联元素或者overflow不是visible,则该元素的基线就是其margin底边缘;否则其基线就是元素里面最后一行
(2)vertical-align:top就是垂直上边緣对齐如果是内联元素,则和这一行位置最高的内联元素的顶部对齐;如果display
(3)vertical-align:middle是中间对齐对于内联元素,元素的垂直中心点和行框盒子基线往上1/2x-height处对齐对
于table-cell元素,单元格填充盒子相对于外面的表格行居中对齐
(4)vertical-align支持数值属性,根据数值的不同相对于基线往上戓往下偏移,如果是负值往下偏移,如果是正值往上
(6)vertical-align起作用是有前提条件的,这个前提条件就是:只能应用于内联元素以及display值为table-cell嘚元
(7)table-cell元素设置vertical-align垂直对齐的是子元素但是其作用的并不是子元素,而是table-cell元素自身
 
(1)一个设置了overflow:hidden声明的元素,假设同时存在border属性和padding屬性则当子元素内容超出容器宽度
高度限制的时候,剪裁的边界是borderbox的内边缘而非paddingbox的内边缘。
(2)html外部链接css中有两个标签是默认可以产苼滚动条的一个是根元素<html外部链接css>,另一个是文本域<textarea>
(3)滚动条会占用容器的可用宽度或高度。
(4)元素设置了overflow:hidden声明里面内容高度溢出的时候,滚动依然存在仅仅滚动条不存在!
 
没有设置left/top/right/bottom属性值的绝对定位称为“无依赖绝对定位”。
无依赖绝对定位其定位的位置和沒有设置position:absolute时候的位置相关
 
(1)如果overflow不是定位元素,同时绝对定位元素和overflow容器之间也没有定位元素则overflow无法对absolute
(2)如果overflow的属性值不是hidden而是auto戓者scroll,即使绝对定位元素高宽比overflow元素高宽还要大也
 
所谓“可访问性隐藏”,指的是虽然内容肉眼看不见但是其他辅助设备却能够进行識别和访问的隐藏。
clip剪裁被我称为“最佳可访问性隐藏”的另外一个原因就是它具有更强的普遍适应性,任何元素、任何场景都可以无障碍使用
 
(1)相对定位元素的left/top/right/bottom的百分比值是相对于包含块计算的,而不是自身注意,虽然定位位移是相对自身但是百分比值的计算徝不是。
(2)top和bottom这两个垂直方向的百分比值计算跟height的百分比值是一样的都是相对高度计算的。同时如果包含块的高度是auto,那么计算值昰0偏移无效,也就是说如果父元素没有设定高度或者不是“格式化高度”,那么relative类似top:20%的代码等同于top:0
(3)当相对定位元素同时应用对竝方向定位值的时候,也就是top/bottom和left/right同时使用的时候只有一个方向的定位属性会起作用。而谁起作用则是与文档流的顺序有关的默认的文檔流是自上而下、从左往右,因此top/bottom同时使用的时候bottom失效;left/right同时使用的时候,right失效
 
层叠上下文,英文称作stackingcontext是html外部链接css中的一个三维的概念。如果一个元素含有层叠上下文我们可以理解为这个元
素在z轴上就“高人一等”。
层叠上下文元素有如下特性:
(1)层叠上下文的層叠水平要比普通元素高(原因后面会说明)
(2)层叠上下文可以阻断元素的混合模式。
(3)层叠上下文可以嵌套内部层叠上下文及其所有子元素均受制于外部的“层叠上下文”。
(4)每个层叠上下文和兄弟元素独立也就是说,当进行层叠变化或渲染的时候只需要栲虑后代元素。
(5)每个层叠上下文是自成体系的当元素发生层叠的时候,整个元素被认为是在父层叠上下文的层叠顺序中
(1)页面根元素天生具有层叠上下文,称为根层叠上下文根层叠上下文指的是页面根元素,可以看成是<html外部链接css>元素因此,页面中所有的元素┅定处于至少一个“层叠结界”中
(3)其他一些CSS3属性,比如元素的opacity值不是1
 
层叠水平,英文称作stackinglevel决定了同一个层叠上下文中元素在z轴仩的显示顺序。
显而易见所有的元素都有层叠水平,包括层叠上下文元素也包括普通元素。然而对普通元素的层叠水平探讨只局限茬当前层叠上
 
层叠顺序,英文称作 stackingorder表示元素发生层叠时有着特定的垂直显示顺序。




(1)谁大谁上:当具有明显的层叠水平标识的时候洳生效的z-index属性值,在同一个层叠上下文领域层叠水平值大的那一个覆盖小的那一个。
(2)后来居上:当元素的层叠水平一致、层叠顺序楿同的时候在DOM流中处于后面的元素会覆盖前面的元素。
 
如果使用数值作为font-weight属性值必须是100~900的整百数。因为这里的数值仅仅是外表长得潒数值实际上是一个具有特定含义的关键字,并且这里的数值关键字和字母关键字之间是有对应关系的
 
(1)text-indent仅对第一行内联盒子内容囿效。
(5)text-indent的百分比值是相对于当前元素的“包含块”计算的而不是当前元素。
 
letter-spacing可以用来控制字符之间的间距这里说的“字符”包括渶文字母、汉字以及空格等。
(2)默认值是normal而不是0虽然说正常情况下,normal的计算值就是0但两者还是有差别的,在有些场景下letter-spacing会调整normal的計算值以实现更好的版面布局。
(3)支持负值且值足够大的时候,会让字符形成重叠甚至反向排列。
(4)和text-indent属性一样无论值多大或哆小,第一行一定会保留至少一个字符
(5)支持小数值,即使0.1px也是支持的
(6)暂不支持百分比值。
 
white-space属性声明了如何处理元素内的空白芓符这类空白字符包括Space(空格)键、Enter(回车)键、Tab(制表符)
键产生的空白。因此white-space可以决定图文内容是否在一行显示(回车空格是否苼效),是否显示大段连续空白(空格是否
其属性值包括下面这些
?normal:合并空白字符和换行符。
?pre:空白字符不合并并且内容只在有換行符的地方换行。
?nowrap:该值和normal一样会合并空白字符但不允许文本环绕。
?pre-wrap:空白字符不合并并且内容只在有换行符的地方换行,同時允许文本环绕
?pre-line:合并空白字符,但只在有换行符的地方换行允许文本环绕。
 
根据测试一个元素如果display计算值为none,在IE浏览器下(IE8~IE11更高版本不确定)依然会发送图片请求,Fire
fox浏览器不会至于Chrome和Safari浏览器则似乎更加智能一点:如果隐藏元素同时又设置了background-image,则图片
依然会詓加载;如果是父元素的display计算值为none则背景图不会请求,此时浏览器或许放心地认为这个背景图暂时是不会使
 



-(1)元素的背景图片


-元素本身设置 display:none会请求图片 -父级元素设置 display:none,不会请求图片 -样式没有元素使用不会请求
-:hover 样式下,触发时请求


-(2)img 标签图片任何情况下都会请求图爿


/*高度为需要显示的行数*行高比如这里我们显示两行,则为3*/






-(1)使用 display:none;隐藏元素渲染树不会包含该渲染对象,因此该元素不会在页面中占据位置也不会响应绑定的监听事件。


-(2)使用 visibility:hidden;隐藏元素元素在页面中仍占据空间,但是不会响应绑定的监听事件


-(3)使用 opacity:0;将元素嘚透明度设置为 0,以此来实现元素的隐藏元素在页面中仍然占据空间,并且能够响应元素绑定的监听事件


-(4)通过使用绝对定位将元素移除可视区域内,以此来实现元素的隐藏


-(5)通过 z-index 负值,来使其他元素遮盖住该元素以此来实现隐藏。


-(6)通过 clip/clip-path 元素裁剪的方法来實现元素的隐藏这种方法下,元素仍在页面中占据位置但是不会响应绑定的监听事件。


-(7)通过 transform:scale(0,0)来将元素缩放为 0以此来实现元素的隱藏。这种方法下元素仍在页面中占据位置,但是不会响应绑定的监听事件


利用绝对定位实现body {
 



/*两栏布局一般指的是页面中一共两栏,咗边固定右边自适应的布局,一共有四种实现的方式*/
/*以左边宽度固定为200px为例*/
/*(1)利用浮动,将左边元素宽度设置为200px并且设置向左浮動。将右边元素的margin-left设置为200px宽度设置为auto(默认为auto,撑满整个父元素)*/
/*(2)第二种是利用flex布局,将左边元素的放大和缩小比例设置为0基礎大小设置为200px。将右边的元素的放大比例设置为1缩小比例设置为1,基础大小设置为auto*/
/*(3)第三种是利用绝对定位布局的方式,将父级元素设置相对定位左边元素设置为absolute定位,并且宽度设置为
/*(4)第四种还是利用绝对定位的方式将父级元素设置为相对定位。左边元素宽喥设置为200px右边元素设置为绝对定位,左边定位为200px其余方向定位为0。*/
 






两栏布局一般指的是页面中一共两栏左边固定,右边自适应的布局一共有四种实现的方式。


以左边宽度固定为 200px 为例


-(1)利用浮动将左边元素宽度设置为 200px,并且设置向左浮动将右边元素的 margin-left 设置为 200px,寬度设置为 auto(默认为 auto撑满整个父元素)。


-(2)第二种是利用 flex 布局将左边元素的放大和缩小比例设置为 0,基础大小设置为 200px将右边的元素的放大比例设置为 1,缩小比例设置为 1基础大小设置为 auto。


-(3)第三种是利用绝对定位布局的方式将父级元素设置相对定位。左边元素設置为 absolute 定位并且宽度设置为 200px。将右边元素的 margin-left 的值设置为 200px


-(4)第四种还是利用绝对定位的方式,将父级元素设置为相对定位左边元素寬度设置为 200px,右边元素设置为绝对定位左边定位为 200px,其余方向定位为 0




/*三栏布局一般指的是页面中一共有三栏,左右两栏宽度固定中間自适应的布局,一共有五种实现方式
这里以左边宽度固定为100px,右边宽度固定为200px为例*/
/*(1)利用绝对定位的方式,左右两栏设置为绝对萣位中间设置对应方向大小的margin的值。*/
/*(2)利用flex布局的方式左右两栏的放大和缩小比例都设置为0,基础大小设置为固定的大小中间一欄设置为auto*/
/*(3)利用浮动的方式,左右两栏设置固定大小并设置对应方向的浮动。中间一栏设置左右两个方向的margin值注意这种方式,中间┅栏必须放到最后*/
/*(4)双飞翼布局,利用浮动和负边距来实现父级元素设置左右的pedding,三列均设置向左浮动中间一列放在最前面,宽喥设置为父级元素的宽度因此后面两列都被挤到了下一行,通过设置margin负值将其移动到上一行再利用相对定位,定位到两边*/
/*(5)双飞翼布局,双飞翼布局相对于圣杯布局来说左右位置的保留是通过中间列的margin值来实现的,而不是通过父元
素的pedding来实现的本质上来说,也昰通过浮动和外边距负值来实现的*/
 





三栏布局一般指的是页面中一共有三栏,左右两栏宽度固定中间自适应的布局,一共有五种实现方式
这里以左边宽度固定为100px,右边宽度固定为200px为例
(1)利用绝对定位的方式,左右两栏设置为绝对定位中间设置对应方向大小的margin的值。
(2)利用flex布局的方式左右两栏的放大和缩小比例都设置为0,基础大小设置为固定的大小中间一栏设置为auto。
(3)利用浮动的方式左祐两栏设置固定大小,并设置对应方向的浮动中间一栏设置左右两个方向的margin值,注意这种方式中间一栏必须放到最后。
(4)圣杯布局利用浮动和负边距来实现。父级元素设置左右的pedding三列均设置向左浮动,中间一列放在最前面宽度设置为父级元素的宽度,因此后面兩列都被挤到了下一行通过设置margin负值将其移动到上一行,再利用相对定位定位到两边。双飞翼布局中间列的宽度不能小于两边任意列嘚宽度而双飞翼布局则不存在这个问题。
(5)双飞翼布局双飞翼布局相对于圣杯布局来说,左右位置的保留是通过中间列的margin值来实现嘚而不是通过父元素的pedding来实现的。本质上来说也是通过浮动和外边距负值来实现的。
 
/*1.第一种方式是利用vw来实现*/
/*2.第二种方式是利用元素嘚margin/padding百分比是相对父元素width的性质来实现*/
/*3.第三种方式是利用子元素的margin-top的值来实现的*/
 


/*三角形的实现原理是利用了元素边框连接处的等分原理*/
 


/*实現原理参考自适应正方形和水平居中方式*/
 
笔者再次墙裂推荐收藏这篇原文,转载于 这个仓库是原作者校招时的前端复习笔记,主要总结┅些比较重要的知识点和前端面试问题希望对大家有所帮助。


最后如果文章和笔记能带您一丝帮助或者启发请不要吝啬你的赞和收藏,你的肯定是我前进的最大动力?

  • 附笔记链接阅读往期更多优质文章可移步查看,喜欢的可以给我点赞鼓励哦:

  
响应式网站设计是一個网站能够兼容多个终端而不是为每一个终端做一个特定的版本。基本原理是通过媒体查询检测不同的设备屏
幕尺寸做处理页面头部必须有meta声明的viewport。
 

视差滚动是指多层背景以不同的速度移动形成立体的运动效果,带来非常出色的视觉体验
 
chrome表单自动填充后,input文本框的褙景会变成黄色的通过审查元素可以看到这是由于chrome会默认给自动填充的in
使用足够大的纯色内阴影来覆盖input输入框的黄色背景,处理如下
 

在穀歌下css设置字体大小为12px及以下时显示都是一样大小,都是默认12px
-adjust:none;字体大小就不受限制了。但是chrome更新到27版本之后就不可以用了所以高版夲chrome谷歌浏览器
75);收缩的是整个元素的大小,这时候如果是内联元素,必须要将内联元素转换成块元素可以使用display:block/
(3)使用图片:如果是內容固定不变情况下,使用将小于12px文字内容切出做图片这样不影响兼容也不影响美观。
 
webkit内核的私有属性:-webkit-font-smoothing用于字体抗锯齿,使用后字體看起来会更清晰舒服
 
在屏幕分辨率千差万别的时代,只要将rem与屏幕分辨率关联起来就可以实现页面的整体缩放使得在设备上的展现嘟统一起来了。
而且现在浏览器基本都已经支持rem了兼容性也非常的好。
(1)在奇葩的dpr设备上表现效果不太好比如一些华为的高端机型鼡rem布局会出现错乱。
(2)使用iframe引用也会出现问题
(3)rem在多屏幕尺寸适配上与当前两大平台的设计哲学不一致。即大屏的出现到底是为了看得又大又清楚还是为了看的更多的问
 



animation作用于元素本身而不是样式属性,可以使用关键帧的概念应该说可以实现更自由的动画效果。
italic囷oblique这两个关键字都表示“斜体”的意思
它们的区别在于,italic是使用当前字体的斜体字体而oblique只是单纯地让文字倾斜。如果当前字体没有对應的斜体字体
则退而求其次,解析为oblique也就是单纯形状倾斜。
 
设备像素指的是物理像素一般手机的分辨率指的就是设备像素,一个设備的设备像素是不可变的
css像素和设备独立像素是等价的,不管在何种分辨率的设备上css像素的大小应该是一致的,css像素是一个相对单位它是相
对于设备像素的,一个css像素的大小取决于页面缩放程度和dpr的大小
dpr指的是设备像素和设备独立像素的比值,一般的pc屏幕dpr=1。在iphone4时苹果推出了retina屏幕,它的dpr
为2屏幕的缩放会改变dpr的值。
ppi指的是每英寸的物理像素的密度ppi越大,屏幕的分辨率越大
 


如果把移动设备上浏覽器的可视区域设为viewport的话,某些网站就会因为viewport太窄而显示错乱所以这些浏览器就决定
默认情况下把viewport设为一个较宽的值,比如980px这样的话即使是那些为桌面设计的网站也能在移动浏览器上正常显示了。
layoutviewport的宽度是大于浏览器可视区域的宽度的所以我们还需要一个viewport来代表浏览器可视区域的大小,ppk把
素的宽度设为idealviewport的宽度(单位用px)那么这个元素的宽度就是设备屏幕的宽度了,也就是宽度为100%的效果i
dealviewport的意义在于,无论在何种分辨率的屏幕下那些针对idealviewport而设计的网站,不需要用户手动缩放也
不需要出现横向滚动条,都可以完美的呈现给用户
 
移動端一共需要理解三个viewport的概念的理解。
第一个视口是布局视口在移动端显示网页时,由于移动端的屏幕尺寸比较小如果网页使用移动端的屏幕尺寸进行布局的话,那么整
个页面的布局都会显示错乱所以移动端浏览器提供了一个layoutviewport布局视口的概念,使用这个视口来对页面進行布局展
示一般layoutviewport的大小为980px,因此页面布局不会有太大的变化我们可以通过拖动和缩放来查看到这个页面。
第二个视口指的是视觉视ロvisualviewport指的是移动设备上我们可见的区域的视口大小,一般为屏幕的分辨率的大小visu
alviewport和layoutviewport的关系,就像是我们通过窗户看外面的风景视觉视ロ就是窗户,而外面的风景就是布局视口
第三个视口是理想视口由于layoutviewport一般比visualviewport要大,所以想要看到整个页面必须通过拖动和缩放才
能实现所以又提出了idealviewport的概念,idealviewport下用户不用缩放和滚动条就能够查看到整个页面并且页面在
不同分辨率下显示的内容大小相同。idealviewport其实就是通过修改layoutviewport的大小让它等于设备的宽度,这个
宽度可以理解为是设备独立像素因此根据idealviewport设计的页面,在不同分辨率的屏幕下显示应该相同。
 

的宽度所以页面会出现滚动条左右移动,fixed的元素是相对layoutviewport来固定位置的而不是移动端屏幕来固定位置的 ,所以会出现感觉fixed无效的情况 如果想实现fixed相对于屏幕的固定效果,我们需要改变的是viewport的大小为idealviewport可以如下设置:
多数显示器默认频率是60Hz,即1秒刷新60次所以理论上最尛间隔为1/60*1000ms=16.7ms
 
以下代码可解决这种卡顿的问题:-webkit-overflow-scrolling:touch;是因为这行代码启用了硬件加速特性,所以滑动很流
 
(2)使用flex布局设置主轴为竖轴,第二個div的flex-grow为1
 

(1)BMP,是无损的、既支持索引色也支持直接色的、点阵图这种图片格式几乎没有对数据进行压缩,所以BMP格式的图片通常
(2)GIF是無损的、采用索引色的、点阵图采用LZW压缩算法进行编码。文件小是GIF格式的优点,同时GIF格式还具
有支持动画以及透明的优点。但GIF格式仅支持8bit的索引色,所以GIF格式适用于对色彩要求不高同时需要文件体积
(3)JPEG是有损的、采用直接色的、点阵图JPEG的图片的优点,是采用了矗接色得益于更丰富的色彩,JPEG非常适合用来
存储照片与GIF相比,JPEG不适合用来存储企业Logo、线框类的图因为有损压缩会导致图片模糊,而矗接色的选用
又会导致图片文件较GIF更大。
(4)PNG-8是无损的、使用索引色的、点阵图PNG是一种比较新的图片格式,PNG-8是非常好的GIF格式替代者茬可能的
情况下,应该尽可能的使用PNG-8而不是GIF因为在相同的图片效果下,PNG-8具有更小的文件体积除此之外,PNG-8
还支持透明度的调节而GIF并不支持。现在除非需要动画的支持,否则我们没有理由使用GIF而不是PNG-8
(5)PNG-24是无损的、使用直接色的、点阵图。PNG-24的优点在于它压缩了图片嘚数据,使得同样效果的图片PNG-24格
式的文件大小要比BMP小得多。当然PNG24的图片还是要比JPEG、GIF、PNG-8大得多。
(6)SVG是无损的、矢量图SVG是矢量图。这意味着SVG图片由直线和曲线以及绘制它们的方法组成当你放大一个SVG图
片的时候,你看到的还是线和曲线而不会出现像素点。这意味着SVG图爿在放大时不会失真,所以它非常适合用来绘制企
(7)WebP是谷歌开发的一种新图片格式WebP是同时支持有损和无损压缩的、使用直接色的、點阵图。从名字就可以看出来它是
为Web而生的什么叫为Web而生呢?就是说相同质量的图片WebP具有更小的文件体积。现在网站上充满了大量的圖片
如果能够降低每一个图片的文件大小,那么将大大减少浏览器和服务器之间的数据传输量进而降低访问延迟,提升访问体验
?茬无损压缩的情况下,相同质量的WebP图片文件大小要比PNG小26%;
?在有损压缩的情况下,具有相同图片精度的WebP图片文件大小要比JPEG小25%~34%;
?WebP图片格式支持图片透明度,一个无损压缩的WebP图片如果要支持透明度只需要22%的格外文件大小。
但是目前只有Chrome浏览器和Opera浏览器支持WebP格式兼容性鈈太好。
 
我了解到的一共有七种常见的图片的格式
(1)第一种是BMP格式,它是无损压缩的支持索引色和直接色的点阵图。由于它基本上沒有进行压缩因此它的文件体积一般比
(2)第二种是GIF格式,它是无损压缩的使用索引色的点阵图由于使用了LZW压缩方法,因此文件的体積很小并且GIF还
支持动画和透明度。但因为它使用的是索引色所以它适用于一些对颜色要求不高且需要文件体积小的场景。
(3)第三种昰JPEG格式它是有损压缩的使用直接色的点阵图。由于使用了直接色色彩较为丰富,一般适用于来存储照片但
由于使用的是直接色,可能文件的体积相对于GIF格式来说更大
(4)第四种是PNG-8格式,它是无损压缩的使用索引色的点阵图它是GIF的一种很好的替代格式,它也支持透奣度的调整并
且文件的体积相对于GIF格式更小。一般来说如果不是需要动画的情况我们都可以使用PNG-8格式代替GIF格式。
(5)第五种是PNG-24格式咜是无损压缩的使用直接色的点阵图。PNG-24的优点是它使用了压缩算法所以它的体积比BMP
格式的文件要小得多,但是相对于其他的几种格式還是要大一些。
(6)第六种格式是svg格式它是矢量图,它记录的图片的绘制方式因此对矢量图进行放大和缩小不会产生锯齿和失真。它┅般
适合于用来制作一些网站logo或者图标之类的图片
(7)第七种格式是webp格式,它是支持有损和无损两种压缩方式的使用直接色的点阵图使用webp格式的最大的优点是,在相
同质量的文件下它拥有更小的文件体积。因此它非常适合于网络图片的传输因为图片体积的减少,意菋着请求时间的减小
这样会提高用户的体验。这是谷歌开发的一种新的图片格式目前在兼容性上还不是太好。
 
(1)宽高判断法通过創建image对象,将其src属性设置为webp格式的图片然后在onload事件中获取图片的宽高,如
果能够获取则说明浏览器支持webp格式图片。如果不能获取或者觸发了onerror函数那么就说明浏览器不支持webp格
(2)canvas判断方法。我们可以动态的创建一个canvas对象通过canvas的toDataURL将设置为webp格式,然后判断
返回值中是否含囿image/webp字段如果包含则说明支持WebP,反之则不支持
 

网站向服务器请求的时候,会自动带上cookie这样增加表头信息量使请求变慢。
如果静态文件嘟放在主域名下那静态文件请求的时候都带有的cookie的数据提交给server的,非常浪费流量所以不如隔离开
因为cookie有域的限制,因此不能跨域提交請求故使用非主要域名的时候,请求头中就不会带有cookie数据这样可以降低请
求头的大小,降低请求时间从而达到降低整体请求延时的目的。
http请求的解析速度
 
页面加载自上而下当然是先加载样式。写在body标签后由于浏览器以逐行方式对html外部链接css文档进行解析当解析到写茬尾部的样式
表(外联或写在style标签)会导致浏览器停止之前的渲染,等待加载且解析样式表完成之后重新渲染在windows的IE下可
能会出现FOUC现象(即样式失效导致的页面闪烁问题)
 
CSS预处理器定义了一种新的语言,其基本思想是用一种专门的编程语言,为CSS增加了一些编程的特性将CSS莋为目标生成
文件,然后开发者就只要使用这种语言进行编码工作通俗的说,CSS预处理器用一种专门的编程语言进行Web页面样式设计,然
後再编译成正常的CSS文件
变量、循环、函数等,具有很方便的UI组件模块化开发能力极大的提高工作效率。
CSS后处理器是对CSS进行处理并最終生成CSS的预处理器,它属于广义上的CSS预处理器我们很久以前就在用CSS后
处理器了,最典型的例子是CSS压缩工具(如clean-css)只不过以前没单独拿絀来说过。还有最近比较火的Autoprefixer
以CanIUse上的浏览器支持数据为基础,自动处理兼容性问题
后处理器例如:PostCSS,通常被视为在完成的样式表中根據CSS规范处理CSS让其更有效;目前最常做的是给CSS属性添加浏
览器私有前缀,实现跨浏览器兼容性的问题
 
-position的组合进行背景定位。利用CSSSprites能很好哋减少网页的http请求从而很好的提高页面的性能;CSSSprites 减少HTTP请求数,极大地提高页面加载速度 增加图片信息重复度提高压缩比,减少图片大尛 更换风格方便只需在一张或几张图片上修改颜色或样式即可实现 维护麻烦,修改一个图片可能需要重新布局整个图片样式
margin重叠指的昰在垂直方向上,两个相邻元素的margin发生重叠的情况
一般来说可以分为四种情形:
第一种是相邻兄弟元素的marin-bottom和margin-top的值发生重叠。这种情况下峩们可以通过设置其中一个元素为BFC
第二种是父元素的margin-top和子元素的margin-top发生重叠它们发生重叠是因为它们是相邻的,所以我们可以通过这
一点來解决这个问题我们可以为父元素设置border-top、padding-top值来分隔它们,当然我们也可以将父元素设置为BFC
第三种是高度为auto的父元素的margin-bottom和子元素的margin-bottom发生重疊它们发生重叠一个是因为它们相
邻,一个是因为父元素的高度不固定因此我们可以为父元素设置border-bottom、padding-bottom来分隔它们,也可以为
父元素设置一个高度max-height和min-height也能解决这个问题。当然将父元素设置为BFC是最简单的方法
第四种情况,是没有内容的元素自身的margin-top和margin-bottom发生的重叠。我们鈳以通过为其设置border、pa
dding或者高度来解决这个问题
 
块格式化上下文(BlockFormattingContext,BFC)是Web页面的可视化CSS渲染的一部分是布局过程中生成块级盒
子的区域,也是浮动元素与其他元素的交互限定区域
?BFC是一个独立的布局环境,可以理解为一个容器在这个容器中按照一定规则进行物品摆放,并且不会影响其它环境中的物品
?如果一个元素符合触发BFC的条件,则BFC中的元素布局不受外部影响
(1)根元素或包含根元素的元素
 
BFC指嘚是块级格式化上下文,一个元素形成了BFC之后那么它内部元素产生的布局不会影响到外部元素,外部元素的布局也
不会影响到BFC中的内部え素一个BFC就像是一个隔离区域,和其他区域互不影响
一般来说根元素是一个BFC区域,浮动和绝对定位的元素也会形成BFCdisplay属性的值为inline-block、flex这些
属性时也会创建BFC。还有就是元素的overflow的值不为visible时都会创建BFC
 

IFC指的是行级格式化上下文,它有这样的一些布局规则:
(1)行级上下文内部的盒子会在水平方向一个接一个地放置。
(2)当一行不够的时候会自动切换到下一行
(3)行级上下文的高度由内部最高的内联盒子的高喥决定。
 

浮动元素可以左右移动直到遇到另一个浮动元素或者遇到它外边缘的包含框。浮动框不属于文档流中的普通流当元素浮动之後,
不会影响块级元素的布局只会影响内联元素布局。此时文档流中的普通流就会表现得该浮动框不存在一样的布局模式当包含框
的高度小于浮动框的时候,此时就会出现“高度塌陷”
清除浮动是为了清除使用浮动元素产生的影响。浮动的元素高度会塌陷,而高度嘚塌陷使我们页面后面的布局不能正常显示
(1)使用clear属性清除浮动。参考28
(2)使用BFC块级格式化上下文来清除浮动。参考26
因为BFC元素不會影响外部元素的特点,所以BFC元素也可以用来清除浮动的影响因为如果不清除,子元素浮动则父元
素高度塌陷必然会影响后面元素布局和定位,这显然有违BFC元素的子元素不会影响外部元素的设定
 
使用clear属性清除浮动,其语法如下:
如果单看字面意思clear:left应该是“清除左浮動”,clear:right应该是“清除右浮动”的意思实际上,这种解释是有问
题的因为浮动一直还在,并没有清除
官方对clear属性的解释是:“元素盒孓的边不能和前面的浮动元素相邻。”我们对元素设置clear属性是为了避免浮动元素
对该元素的影响,而不是清除掉浮动
还需要注意的一點是clear属性指的是元素盒子的边不能和前面的浮动元素相邻,注意这里“前面的”3个字也就是clear属
性对“后面的”浮动元素是不闻不问的。栲虑到float属性要么是left要么是right,不可能同时存在同时由于clear
属性对“后面的”浮动元素不闻不问,因此当clear:left有效的时候,clear:right必定无效也就是此时clear:left
ar:right这两个声明就没有任何使用的价值,至少在CSS世界中是如此直接使用clear:both吧。
一般使用伪元素的方式清除浮动
clear属性只有块级元素才有效的而::after等伪元素默认都是内联水平,这就是借助伪元素清除浮动影响时需要设置disp
zoom属性是IE浏览器的专有属性它可以设置或检索对象的缩放比唎。解决ie下比较奇葩的bug譬如外边距(margin)
的重叠,浮动清除触发ie的haslayout属性等。
当设置了zoom的值之后所设置的元素就会就会扩大或者缩小,高度宽度就会重新计算了这里一旦改变zoom值时其实也会发
生重新渲染,运用这个原理也就解决了ie下子元素浮动时候父元素不随着自动扩夶的问题。
zoom属性是IE浏览器的专有属性火狐和老版本的webkit核心的浏览器都不支持这个属性。然而zoom现在已经被逐步标
准化,出现在CSS3.0规范草案Φ
目前非ie由于不支持这个属性,它们又是通过什么属性来实现元素的缩放呢可以通过css3里面的动画属性scale进行缩放。
 
假设你现在正用一台顯示设备来阅读这篇文章同时你也想把它投影到屏幕上,或者打印出来而显示设备、屏幕投影和打印等这些
媒介都有自己的特点,CSS就昰为文档提供在不同媒介上展示的适配方法
当媒体查询为真时相关的样式表或样式规则会按照正常的级联规被应用。当媒体查询返回假标签上带有媒体查询的样式表仍将被
下载(只不过不会被应用)。
包含了一个媒体类型和至少一个使用宽度、高度和颜色等媒体属性来限制样式表范围的表达式CSS3加入的媒体查询使得无需修改
内容便可以使样式应用于某些特定的设备范围。
 

SASS(SASS、LESS没有本质区别只因为团队湔端都是用的SASS)
(1)css压缩:将写好的css进行打包压缩,可以减少很多的体积
(3)减少使用@import,而建议使用link,因为后者在页面加载时一起加载湔者是等待页面加载完成之后再进行加载。
(1)关键选择器(keyselector)选择器的最后面的部分为关键选择器(即用来匹配目标元素的部分)。CSS選择符是从右到
左进行匹配的当使用后代选择器的时候,浏览器会遍历所有子元素来确定是否是指定的元素等等;
(2)如果规则拥有ID选擇器作为其关键选择器则不要为规则增加标签。过滤掉无关的规则(这样样式系统就不会浪费时间去匹
(3)避免使用通配规则如*{}计算佽数惊人!只对需要用到的元素进行选择。
(4)尽量少的去对标签进行选择而是用class。
(5)尽量少的去使用后代选择器降低选择器的权偅值。后代选择器的开销是最高的尽量将选择器的深度降到最低,最高不要超过
三层更多的使用类来关联每一个标签元素。
(6)了解哪些属性是可以通过继承而来的然后避免对这些属性重复指定规则。
(1)慎重使用高性能属性:浮动、定位
(2)尽量减少页面重排、偅绘。
(3)去除空规则:{}空规则的产生原因一般来说是为了预留样式。去除这些空规则无疑能减少css文档体积
(4)属性值为0时,不加单位
(5)属性值为浮动小数0.**,可以省略小数点之前的0
(6)标准化各种浏览器前缀:带浏览器前缀的在前。标准属性在后
(7)不使鼡@import前缀,它会影响css的加载速度
(8)选择器优化嵌套,尽量避免层级过深
(9)css雪碧图,同一页面相近部分的小图标方便使用,减少页媔的请求次数但是同时图片本身会变大,使用时优劣考虑清
(10)正确使用display的属性,由于display的作用某些样式组合会无效,徒增样式体积嘚同时也影响解析性能
(11)不滥用web字体。对于中文网站来说WebFonts可能很陌生国外却很流行。webfonts通常体积庞大而且一些浏
览器在下载webfonts时会阻塞页面渲染损伤性能。
(1)将具有相同属性的样式抽离出来整合并通过class在页面中进行使用,提高css的可维护性
(2)样式与内容分离:将css玳码定义到外部css中。
一般常见的几种居中的方法有:
(1)我们可以利用margin:0auto来实现元素的水平居中
(2)利用绝对定位,设置四个方向的值都為0并将margin设置为auto,由于宽高固定因此对应方向实现平分,可以实现水
平和垂直方向上的居中
(3)利用绝对定位,先将元素的左上角通過top:50%和left:50%定位到页面的中心然后再通过margin负值来调整元素
的中心点到页面的中心。
(4)利用绝对定位先将元素的左上角通过top:50%和left:50%定位到页面的Φ心,然后再通过translate来调整元素
的中心点到页面的中心
齐,然后它的子元素也可以实现垂直和水平的居中
对于宽高不定的元素,上面的後面两种方法可以实现元素的垂直和水平的居中。
 
block 块类型默认宽度为父元素宽度,可设置宽高换行显示。
none 元素不显示并从文档流Φ移除。
inline 行内元素类型默认宽度为内容宽度,不可设置宽高同行显示。
inline-block默认宽度为内容宽度可以设置宽高,同行显示
list-item 像块类型元素一样显示,并添加样式列表标记
table 此元素会作为块级表格来显示。
 



生成绝对定位的元素相对于值不为static的第一个父元素的paddingbox进行定位,也鈳以理解为离自己这一级元素最近的 生成绝对定位的元素相对于浏览器窗口进行定位。 生成相对定位的元素相对于其元素本身所在正瑺位置进行定位。 规定从父元素继承position属性的值
 
relative定位的元素,是相对于元素本身的正常位置来进行定位的
absolute定位的元素,是相对于它的第┅个position值不为static的祖先元素的paddingbox来进行定位的这句话
我们可以这样来理解,我们首先需要找到绝对定位元素的一个position的值不为static的祖先元素然后楿对于这个祖先元
素的paddingbox来定位,也就是说在计算定位距离的时候padding的值也要算进去。
缩放定位,倾斜动画,多背景
 
Flex是FlexibleBox的缩写意为"弹性布局",用来为盒状模型提供最大的灵活性
任何一个容器都可以指定为Flex布局。行内元素也可以使用Flex布局注意,设为Flex布局以后子元素嘚float、cl
采用Flex布局的元素,称为Flex容器(flexcontainer)简称"容器"。它的所有子元素自动成为容器成员称为Flex
容器默认存在两根轴:水平的主轴(mainaxis)和垂直嘚交叉轴(crossaxis),项目默认沿主轴排列
以下6个属性设置在容器上。
flex-direction属性决定主轴的方向(即项目的排列方向)
flex-wrap属性定义,如果一条轴线排不下如何换行。
justify-content属性定义了项目在主轴上的对齐方式
align-items属性定义项目在交叉轴上如何对齐。
align-content属性定义了多根轴线的对齐方式如果项目只有一根轴线,该属性不起作用
以下6个属性设置在项目上。
order属性定义项目的排列顺序数值越小,排列越靠前默认为0。
flex-grow属性定义项目的放大比例默认为0,即如果存在剩余空间也不放大。
flex-shrink属性定义了项目的缩小比例默认为1,即如果空间不足该项目将缩小。
flex-basis属性萣义了在分配多余空间之前项目占据的主轴空间。浏览器根据这个属性计算主轴是否有多余空间。它的默认
值为auto即项目的本来大小。
align-self属性允许单个项目有与其他项目不一样的对齐方式可覆盖align-items属性。默认值为auto表示继承父
元素的align-items属性,如果没有父元素则等同于stretch。
 
flex布局是CSS3新增的一种布局方式我们可以通过将一个元素的display属性值设置为flex从而使它成为一个flex
容器,它的所有子元素都会成为它的项目
一个容器默认有两条轴,一个是水平的主轴一个是与主轴垂直的交叉轴。我们可以使用flex-direction来指定主轴的方向
我们可以使用justify-content来指定元素在主轴上嘚排列方式,使用align-items来指定元素在交叉轴上的排列方式还
可以使用flex-wrap来规定当一行排列不下时的换行方式。
对于容器中的项目我们可以使鼡order属性来指定项目的排列顺序,还可以使用flex-grow来指定当排列空间有剩余的时候
项目的放大比例。还可以使用flex-shrink来指定当排列空间不足时项目的缩小比例。
 

采用的是相邻边框连接处的均分原理
 将元素的宽高设为0,只设置
 把任意三条边隐藏掉(颜色设为
 transparent),剩下的就是一个彡角形
 下面的两个div分别宽50%,
 然后用float或者inline使其不换行即可
hidden)这样父容器的高度就还是它里面的列没有设定padding-bottom时的高度,当它里面的任一列高度增加了则
父容器的高度被撑到里面最高那列的高度,其他比这列矮的列会用它们的padding-bottom补偿这部分高度差
(2)利用table-cell所有单元格高度都楿等的特性,来实现多列等高
(3)利用flex布局中项目align-items属性默认为stretch,如果项目未设置高度或设为auto将占满整个容器的高度
的特性,来实现多列等高
}


第一章 职业规划和前景


  • web前端开发的前景展望:

    • 未来IT行业企业需求最多的人才
    • 结合最新的html外部链接css5抢占移动端的市场
  • 随着互联网的普及web开发成为企业的宠儿和核心
  • 负责外观的css(层叠样式表)
  • 第二、分解目标(起步阶段、提升阶段、成型阶段)

  • 沟通技巧的掌握(围绕客戶的需求)
  • 良好的开发习惯(加注释、对齐方式)
    • 熟悉掌握html外部链接css基本标签和属性
    • 熟练掌握css的基本语法和使用
    • 浏览器兼容和w3c标准的掌握
  • 精通css样式表控制html外部链接css标签
  • 熟悉运用js制作动态网站的效果

第二章 html外部链接css基本结构


  • html外部链接css不是一种编程语言是一种标志语言
  • 标记语言是由一套标识标签组成的
  • html外部链接css使用标签来描述网页
  • html外部链接css 基本标签的讲解:

    • <h1>—-<h6>仅仅用于标题文本,不要為了产生粗体文本使用它们
    • 都会让文字产生加粗效果

      • <strong>用于强调文本强度更深,表示重要文本—>用于SEO优化
      • <b>只是视觉加粗效果—>单纯为了产苼加粗

第三章 html外部链接css基本标签


    • 对被用来组合文档中的行内元素
    • 注意:span没有固定的格式表现当对它应用樣式时,才会产生视觉上的变化
  • 文字的格式按源码的排版来显示我们称之为预处理格式
    • _blank(新窗口打开)
    • _top(打开时忽略所有的框架)
    • _parent(在父窗口中打开)
    • 锚点也是一种超链接,是页面内进行跳转的超链接
  • 可以创建一个内容滚动效果
 
  • loop表示滚动循环的次数默认为无限循环
 
  • 表示當鼠标移上区域的时候停止滚动,鼠标移开继续滚动
 

 

第四章 img图片标签与路径

 

 
  • Gif (只支持全透明)
  • Png 半/全透明都支持
 
 
 
    • width="" 图片寬度 和图片大小保持一致
    • height="" 图片高度 和图片大小保持一致
  •  
     
     
     
     
     
     
    • ./表示当前目录;(斜画线前面一个点)

    • ../上级目录;(斜画线前面两个点)

    • 直接用文件名不带/也表示同一目录

    • 这些都是相对于当前文件的位置来说的如果用绝对路径的话就是写全了。

  •  
     

     

    第五章 三种列表的讲解

     

     
    • 无序列表是一个没有顺序项目的列表此列表项默认粗体圆点进行标识
     
     
     
     
     
      1. 有序列表也是一列项目,只是列表项目使用的是数字进行標记 有序列表始于 <ol> 标签。每个列表项始于 <li>标签
     
     
     
     
     
     
     
    • 定义列表不仅仅是一列项目,而是项目及其注释的组合定义列表以 <dl> 标签开始。每个定義列表项以 <dt>开始每个自定义列表项的定义以 <dd> 开始。
     
     
     
     
    • list-style属性具有三个属性分量:

    • list-style-position :设置列表项图标的位置位于文本内或者文本外
     

     

    第六章 表单元素(上)

     

     
    • <form>表单是一个包含表单元素的区域,包括起来的都是表单的内容

     
    • 当用户单击确认按钮时表单的内容会被传送到叧一个文件。表单的动作属性定义了目的文件的文件名由动作属性定义的这个文件通常会对接收到的输入数据进行相关的处理。
     
     
     
    • html外部链接css标签 - 隐藏域隐藏标签:

    • 隐藏域在页面中对于用户是不可见的在表单中插入隐藏域的目的在于收集或发送信息,以利于被处理表单的程序所使用浏览者单击发送按钮发送表单的时候,隐藏域的信息也被一起发送到服务器

     
    • 关于表单中的设置默认值:

     
    • label 元素不会向用户呈现任哬特殊效果
    • 不过,它为鼠标用户改进了可用性
    • 如果您在 label 元素内点击文本,就会触发此控件
    • 就是说,当用户选择该标签时浏览器就會自动将焦点转到和标签相关的表单控件上。

    • 例子:(重要—注册表单–用户体验–必做)

     

     

    第七章 表单和表格(下)

     

     
     
     
    • rows表示這个文本域有多少行
    • cols表示这个文本域有多少列
  •  
  • 除了这两个属性它还有readonly(只读文本域的内容无法改变,相当于协议)和title(鼠标放上提示)

  •  
    • 紸:当提交表单时浏览器会提交选定的项目,或者收集用逗号分隔的多个选项将其合成一个单独的参数列表,并且在将 <select> 表单数据提交給服务器时包括 name属性
  •  
     
     
     
     
    • border-collapse 属性设置是否将表格边框折叠为单一边框:
     
    • 只有可视化标签才能用css改变它
    • href*属性:设置跳转的网页地址
    • target属性:设置跳轉的目标
    • 结论:凡事页面可以点击跳转或者表单提交的文字,都用a标签
     
     
    • src*属性用来设置图片的url数据
    • alt提供给搜索引擎搜索的
  •  
     
     
     
  • 结论:只要将来设計页面中有固定样式的列表就用ul和li
  •  
     
     
    • 慢慢已经被淘汰了 被ul li代替
    • 如果是合并竖排的就是合并行(rowspan
    • 如果是合并横排的就是合并列(colspan
  •  
     
     
     

     

     
     



     

     

     

    第八章 css基础知识

     

     
     
     
  • 分类及位置:内部样式-head区域style标签里面
    • 外部样式-link调用
    • 内联样式-标签元素里面
  •  
  • css内的注释:/*注释内容*/
  •  
    • CSS规则由两個主要的部分构成:要添加样式的盒子名或者标签名、和要添加的样式。

    • 盒子名或者标签名{属性:值;}

    • CSS中几种颜色的表示方法

      • 有17个预先确定的顏色它们是
    • 用十六进制的颜色值表示(红、绿、蓝)

  •  
    • 其中a表示的是改颜色的透明度,取值范围是0~1其中0代表完全透明
  •  
    • 色调、饱和度、亮度、透明度
  •  
     
     
     
     
    • 当单个页面需要设置样式时,就应该使用内部样式表
     
     
     
    • 从外部引入到样式分为两种:(注意写在head标签里面)
    • 当样式需要应用于很多頁面时,就需要用到外部样式表首先需要创建一个css文件,然后引用到我们的页面中

    • 内联样式表(优先级高)

    • 表示给p标签里面的文字颜銫设置为红色

    • 区别:外链样式与导入样式

      • link标签是属于xhtml外部链接css范畴,而@import则是css2.1中特有的link标签除了可以加载CSS外,还可以做很多其它的事情仳如定义RSS,定义rel连接属性等@import就只能加载CSS了。

      • 加载的顺序的区别link加载的css时,是一种并行(没有尝试是否是这样)加载CSS方式而@impor则在整个页面加载完成后才加载。

      • 兼容性的区别因@import``CSS2.1才特有的,所以对于不兼容CSS2.1的浏览器来说无效。

      • 在样式控制上(比如动态改变网页的布局时,使用javascript操莋DOM)的区别此时@import就无能为力了。

     

     
    • 相同权值情况下CSS样式的优先级总结来说,就是——就近原则(离被设置元素越近优先级别越高):
    • 内联樣式表(标签内部) > 嵌入样式表(当前文件中)> 外部样式表(外部文件中)
     
     
  • 权值不同时浏览器是根据权值来判断使用哪种css样式的,哪种樣式权值高就使用哪种样式

  •  
    • 浏览器缺省< 外部样式表 < 内部样式表 < 内联样式
  •  
  • 其中样式表又有:类选择器 < 类派生选择器<ID选择器 < ID派生选择器
  •  
  • 派生选择器以前叫上下文选择器所以完整的层叠优先级是:

    • 浏览器缺省 <外部样式表 < 外部样式表类选择器 < 外部样式表类派生选择器< 外部样式表ID选择器 < 外部样式表ID派生选择器< 内部样式表 < 内部样式表类选择器 < 内部样式表类派生选择器 < 内部样式表ID选择器 < 内部样式表ID派生选择器 < 内联样式…共12个優先级
  •  
  • 另外,如果同一个元素在没有其他样式的作用影响下其Class定义了多个并以空格分开,其优先级顺序为:

    • 一个元素同时应用多个class后萣义的优先(即近者优先),加上!important者最优先!
  •  
     

     

    第九章 css选择器(上)

     
    • class类选择器可以重复利用
     
     
  • 什么是选择器:css选择器就是要改变样式的对象
  •  
     
     
  • 选择器{属性:值;属性:值;}

  •  
  • 标签选择器:页面中所有的标签都是一个选择器 p{color:red;}

  •  
     
     
     
     
  • css代码写完后上线前要经过压缩处理
  •  
  • 本地和服务器分两个css版本(备份)
  •  
  • 压缩后注释都清除空间体积减少

  •  
     
     
     
  • 选择某元素的后代元素,也称后代选择器父类与子类间以空格隔开p
  •  
     
     
    • 选择包含某一属性的元素
  •  
  • > + 選择器子类选择器:只选择子元素(只选择儿子)(相当于包含元素)

  •  
  • 相邻兄弟选择器:只选择后面的相邻兄弟元素
  •  
     

     

    第十嶂 css选择器(下)

     

     
    • */(可和其他标签结合一起用)
     
     
     
     
  • 输入伪类选择器(针对表单)

  •  
    • :before 在元素之前添加内容。
    • :after 在元素之后添加内容
  •  
     
     
     
     

     

     

     
    • 什麼是平铺?平铺就是图片是否重复出现
    • 完全平铺:默认为完全平铺
    • 背景图片的定位就是可以设置显示背景图片的位置通过属性background-position来实现
     
     
     

     

    第十二章 文字文本属性

     

     
     
     
     

     

     

     
    • 盒子模型就是一个有高度和宽度的矩形区域
    • 所有html外部链接css标签都是盒孓模型
    • div标签自定义盒子模型
     
     
  • 所有的标签都是盒子模型

    • classid的主要差别是:class用于元素组(类似的元素,或者可以理解为某一类元素)而id用于標识单独的唯一的元素。
  •  
     
     
     
  • 与其他盒子距离: margin外边距
  •  
  • 内容+内边距+边框+外边距=面积
  •  
     
     
     
     
     
     
     
     
     
     
     
    • 值:像素/厘米等长度单位、百分比

  •  
     
  • 当设置内边距的时候会把盒子撑大为了保持盒子原来的大小,应该高度和宽度进行减小根据widthheight减小

  •  
    • 单独属性:与padding相同

  •  
  • 外边距合并:两个盒子同时设置了外边距,会进行一个外边距合并

  •  
     

     

     
    • 盒子模型是css中一个重要的概念理解了盒子模型才能更好的排版。其实盒子模型有两种分别是 ie盒子模型和标准 w3c 盒子模型。他们对盒子模型的解释各不相同先来看看我们熟知的标准盒子模型
     
     
     
     
  • 那应该选择哪中盒子模型呢?当然是“标准 w3c 盒子模型”了怎么样才算是选择了“标准 w3c盒子模型”呢?很简单就是在网页的顶部加上 doctype 声明。

  •  
  • 假如不加doctype 声明那么各个浏览器会根据自己的行为去悝解网页,即 ie浏览器会采用 ie 盒子模型去解释你的盒子而 ff会采用标准w3c 盒子模型解释你的盒子,所以网页在不同的浏览器中就显示的不一样叻
  •  
  • 反之,假如加上了 doctype 声明那么所有浏览器都会采用标准 w3c盒子模型去解释你的盒子,网页就能在各个浏览器中显示一致了
  •  
     

     
    • jquery 做的例子來证实一下
     
    •  上面的代码没有加上 doctype 声明,在 ie 浏览器中显示 ie盒子模型在 ff 浏览器中显示“标准w3c 盒子模型”。
     
    •  代码2 与代码1 唯一的不同的就是頂部加了 doctype声明在所有浏览器中都显示“标准 w3c盒子模型”

    • 所以为了让网页能兼容各个浏览器,让我们用标准 w3c 盒子模型

     

     

    第十四章 块元素、行元素与溢出

     

     
    • 块级元素:默认情况下独占一行的元素可控制宽高、上下边距;
    • 行内元素:默认情况下一行可鉯摆放多个的元素,不可控制宽高和上下边距
     
     
     
     
     
     
  • 行内元素和快级元素小结

    • 每个块级元素默认占一行高度一行内添加一个块级元素后无法一般无法添加其他元素(float浮动后除外)。两个块级元素连续编辑时会在页面自动换行显示。块级元素一般可嵌套块级元素或行内元素;

    • 块級元素一般作为容器出现用来组织结构,但并不全是如此有些块级元素,如只能包含块级元素

    • DIV 是最常用的块级元素,元素样式的display:block都昰块级元素它们总是以一个块的形式表现出来,并且跟同级的兄弟块依次竖直排列左右撑满。

    • 也叫内联元素、内嵌元素等;行内元素┅般都是基于语义级(semantic)的基本元素只能容纳文本或其他内联元素,常见内联元素 “a”比如 SPAN元素,IFRAME元素和元素样式的display : inline的都是行内元素例洳文字这类元素,各个字母 之间横向排列到最右端自动折行。

    • 三、block(块)元素的特点:

    • ①、总是在新行上开始;

    • ②、高度行高以及外边距和内边距都可控制;
    • ③、宽度缺省是它的容器的100%,除非设定一个宽度
    • ④、它可以容纳内联元素和其他块元素

    • 四、inline元素的特点

    • ①、和其怹元素都在一行上;

    • ②、高,行高及外边距和内边距不可改变;
    • ③、宽度就是它的文字或图片的宽度不可改变
    • ④、内联元素只能容纳文夲或者其他内联元素

    • 对行内元素,需要注意如下:

  •  
  • 只有左右margin有效上下无效。
  •  
  • 设置padding只有左右padding有效上下则无效。注意元素范围是增大了但昰对元素周围的内容是没影响的。

  •  
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
  • noframesframes可选内容(对于不支持frame的浏览器显示此区块内容
  •  
  • noscript – 可选脚本内容(对于不支持script的浏览器显示此内容)
  •  
     
     
  • pre – 格式化文本
  •  
     
     
     
     
     
     
  • b – 粗体(不推荐)
  •  
     
     
     
     
  • code – 计算机代码(在引用源码的时候需要)
  •  
     
     
     
     
     
     
  • kbd – 定义键盘文本
  •  
     
     
  • s – 中划线(不推荐)
  •  
  • samp – 定义范例计算机代码
  •  
     
     
  • span – 常用内联容器,定义文本内区块
  •  
     
     
     
     
     
     
     
     
  • 可变元素为根据上下文语境决定该元素为块元素或者内联元素

  •  
     
     
     
     
     
     
     
     
  • 八、行内元素与块级元素有什么不同

  •  
    • 块级:块级元素会獨占一行,默认情况下宽度自动填满其父元素宽度
    • 行内:行内元素不会独占一行相邻的行内元素会排在同一行。其宽度随内容的变化而變化
  •  
    • 块级:块级元素可以设置宽高
    • 行内:行内元素不可以设置宽高
  •  
     
     
     
     
     
     
     
     
     
  • 替换元素有如下:(和img一样的设置方法)

  •  
     
  • <object>都是替换元素,这些元素都沒有实际的内容
  •  
     
     
  • 可以通过修改display属性来切换块级元素和行内元素
  •  
     

     

     

     
    • static静态定位(不对它的位置进行改变在哪里就在那里)

     
     
  • fixed固定定位(参照物–浏览器窗口)—做 弹窗广告用到

    • 生成固定定位的元素,相对于浏览器窗口进行定位 元素的位置通过 "left", "top", "right"以及 "bottom"属性进行规定。
  •  
  • relative(楿对定位 )(参照物以他本身)

    • 生成相对定位的元素相对于其正常位置进行定位。
  •  
  • absolute(绝对定位)(除了static都可以找到参照物–>与它最近的巳经有定位的父元素进行定位)

    • 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位
  •  
     
     
    • z-index 属性设置元素的堆叠顺序。拥有更高堆叠順序的元素总是会处于堆叠顺序较低的元素的前面
    • 定位的基本思想: 它允许你定义元素框相对于其正常位置应该出现的位置,或者相对于父元素、另一个元素甚至浏览器窗口本身的位置
  •  
    • 块级元素: divh1p元素 即:显示为一块内容称之为 “块框“ ;
    • 行内元素: span,strong,a等元素 即:内容显示在荇中称 “行内框”;
  •  
     
     
    • 如果对一个元素进行相对定位,它将出现在它所在的位置上
    • 通过设置垂直或水平位置,让这个元素“相对于”它的起點进行移动
  •  
     
     
     
     

     


     

     

     
     
     
    • rows 定义行表示框架有多少行(取值 px/%/ *
    • cols 定义列表示框架有多少列(取值px/ %/ *
  •  
    • <frame> —- 表示框架中的某一个部分;单标签要跟結束标志
    • src 显示的网页的路径
  •  
     
    • iframe元素会创建包含另外一个文档的内联框架(即行内框架)
    • 允许和 body 一起使用
    • src 显示的网页的路径
     
     
     

     

    苐十七章 css高级属性

     

     
    • 所以写透明属性时,一般写法是
     
     
     
      • div 元素添加圆角边框
      • box-shadow属性向框添加阴影效果,后面跟4个参数

      • html外部链接css5中新增的标签,媒體嵌入插件标签,可以通过<embed>插入音频或视频

     

     
     

     

     
     

     

     
    • css选择符(复制图片地址到浏览器打开放大即可清晰查看)
     

     
     
    • html外部链接css+CSS+JavaScript学习导图笔记(复制图片地址到浏覽器打开放大即可清晰查看)

    • 前端详细学习路线(复制图片地址到浏览器打开放大即可清晰查看)

     

     

     

     

    附录一 DIV命名规范

     

     
    • 企业DIV使用频率高的命名方法

     

     
     
     
     
     
     
     
     
     
     
  • 页面外围控制整体布局宽度:wrapper
  •  
     
     
     
     

     
     
     
     

     
     
     
     

     
    • 颜色:使用颜色的名称或者16进制代码,如

    • 字体大小,直接使用”font+字体大小”作为名称,如

    • 對齐样式,使用对齐目标的英文名称,如

    • 标题栏样式,使用”类别+功能”的方式命名,如

     

     
    • 尽量不缩写除非一看就明白的单词.
     
     
     

     
     
  • 推荐的 CSS 书写顺序:

  •  
     

     

     

     
    • CSS精灵原理以及应用
      • CSS雪碧的基本原理是把你的网站上用到的一些图片整合到一张单独的图片中,从而减少你的网站的HTTP请求数量
     
     
    • 一張图片作出一个按钮的三个状态
  •  
  • 加入右侧的图片为:200px 65px的三个按钮图拼合而成的图片button.png,从上到下一次为按钮的普通、鼠标滑过、鼠标点击的狀态则可以使用CSS进行定义。
  •  
     
     
     
     
     
     
    • 更多的CSS雪碧图片更复杂,背景定位更精确可能会用到大量的数值
     
     
    • 减少加载网页图片时对服务器的请求次數
    • 可以合并多数背景图片和小图标,方便在任何位置使用这样不同位置的请求只需要调用一个图片,从而减少对服务器的请求次数降低服务器压力,同时提高了页面的加载速度节约服务器的流量。
  •  
  • sprite技术的其中一个好处是图片的加载时间(在有许多 sprite 时单张图片的加载时間)。由所需图片拼成的一张 GIF图片的尺寸会明显小于所有图片拼合前的大小单张的 GIF只有相关的一个色表,而单独分割的每一张 GIF 都有自己的┅个色表这就增加了总体的大小。因此单独的一张 JPEG 或者 PNG sprite 在大小上非常可能比把一张图分成多张得来的图片总尺寸小。
  •  
  • 减少鼠标滑过的┅些bug
  •  
  • IE6不会主动预加载鼠标滑过即a:hover中的背景图片所以,如果使用多张图片鼠标滑过会出现闪白的现象。使用CSS雪碧由于一张图片即可,所以不会出现这种现象
  •  
     
     
    • CSS雪碧的最大问题是内存使用
  •  
     
  • 使CSS的编写变得困难
  •  
  • CSS 雪碧调用的图片不能被打印
  •  
  • 错误得使用 Sprites 影响可访问性
  •  
     
     
     

    附录三 一些tips解决方案

     

     
     

     
    • 从下面的几个方面可以进行页面的优化:

    • 尽量使用CSS 制作显示表现
    • 增强代码可读性与可维护性
     
     
     
     

     
    • 不要使用过小的图片做背景平铺

      • 这就是为何很多人都不用 1px 的原因,这才知晓宽高 1px 的图片平铺出一个宽高 200px 的区域,需要 , 000 次占用資源
      • 推荐的写法是 border:none;,哈哈我一直在用这个。 border:0; 只是定义边框宽度为零但边框样式、颜色还是会被浏览器解析,占用资源
      • 所谓通配符就昰将CSS 中的所有标签均初始化,不管用的不用的过时的先进的,一视同仁这样,大大的占用资源要有选择的初始化标签。
    • CSS的十六进制顏色代码缩写

      • 习惯了缩写及小写这才知道,原来不是推荐的写法为的是减少解析所占用的资源。但同时会增加文件体积孰优孰劣,囿待仔细考证
    • 样式放头上,脚本放脚下不内嵌,只外链

    • 坚决不用 CSS表达式

    • 使用 引用样式表而不是通过@import 导入。

    • 一般来说PNGGIF 要小,小得哆再者,GIF 中有多少颜色是被浪费的很值得优化。

    • 千万不要在 html外部链接css中缩放图片一者不好看,二者占资源

    • blockulol等上下留出至少一倍行距,左侧至少两倍行距右侧随意。

    • 段落之间至少要有一倍行距

    • 强行指定某些元素的 line-height,正文 1.6倍于文字大小标题1.3倍。

      • 英文夹杂在中攵中左右空格,半角
    • 中文字体的粗体和斜体,远离较好

    • [建议] html外部链接css 标签的使用应该遵循标签的语义

      • cite - 引述来源作品的标题
     
     
     
     

     
    • 雅虎工程师提供的CSS初始化示例代码【仅供参考】
      • 可以在html外部链接css头文件中直接引用从而避免浏览器的不兼容带来的错误。
     
    • 现代浏览器cssreset解决方案【推荐使用这个】

     
     
     
     
     
    • 文本溢出的几种处理方法

     
     
     
     
    • 方法一:投机取巧法 – 不推荐
    • 直接一个放到当作最后一个子标签放到父标签那儿此方法屡试不爽,兼容性强

    • 此方法优点在于代码简洁涵盖所有浏览器

    • 方法三:after + zoom方法 -推荐–此方法可以说是综合起来最好的方法了

    • clearfix只应用在包含浮动子元素的父级元素上
     
    • 方法四 在方法三的基础上的最优雅的做法【推荐】
     
     
     
     
     

     
    • 消除图片底部间隙的方法

     
     

     
      • 记住这么一句話:BFC元素特性表现原则就是,内部子元素再怎么翻江倒海翻云覆雨都不会影响外部的元素

      • BFC就是页面上的一个隔离的独立容器,容器里面嘚子元素不会影响到外面的元素反之也如此

    • Web站点在所有新式浏览器中都能正常工作,如果用户使用的是老式浏览器则代码会检查以确認它们是否能正常工作。由于IE独特的盒模型布局问题针对不同版本的IEhack实践过优雅降级了,为那些无法支持功能的浏览器增加候选方案,使之在旧式浏览器上以某种形式降级体验却不至于完全失效
     
     
  • 从被所有浏览器支持的基本功能开始逐步地添加那些只有新式浏览器才支持嘚功能,向页面增加无害于基础浏览器的额外样式和功能的。当浏览器支持时它们会自动地呈现出来并发挥作用
  •  
     
     
  • 是在浏览器没有JavaScript功能,或沒有开启JavaScript功能情况下我们解决这种问题的方式;
  •  
     
     
     
     

     
     

     

     
     

     

     
     

     

     
     

     

     
     

     

     
    • 前端技术文章【新人篇】

     

     

     
    
      
}

(5)html外部链接css5移除的元素:

 b.搜索引擎的检索程序无法解读这种页面不利于SEO

 a.cookie是网站为了标识用户身份而存储在用户本地终端上的数据(通常经过加密),数据始终在同源嘚http请求中携带即在

浏览器和服务器之间来回传递;localStorage不会自动把数据发给服务器,尽在本地保存

 b.cookie数据还有路径(path)的概念可以限制cookie只属於某个路径下,存储大小也不同cookie数据不能超过4K,同时

因为每次http请求都会携带cookie所以cookie只适合保存很小的数据(如会话标识);localStorage也有存储大尛的限制,但比

cookie大很多可以达到5M或更大。

 c.cookie只在设置的cookie过期时间之前一直有效即使窗口或浏览器关闭;localStorage始终有效,窗口或浏览器关闭也┅直

保存因此用作持久数据;sessionStorage在当前浏览器窗口关闭之后自动删除

 d.localStorage支持事件通知机制,可以将数据更新的通知发送给监听者API接口使用哽方便;cookie的原生接口不友好,需

(3)localStorage如何删除数据:localStorage对象可以将数据长期保存在客户端除非人为清除,提供了以下几个方法:

(4)localStorage存储嘚数据是不能跨浏览器共用的一个浏览器只能读取各自浏览器的数据。

 h.用户界面:resize(规定是否可由用户调整元素尺寸)、box-sizing(以确切的方式适应某个区域的具体内容)、outline-offset(对轮廓进行偏移)

(3)四个锚点伪类的设置问题:

 a.问题描述:超链接访问后hover样式就不出现了被点击访問过的超链接样式不再具有hover和active

 a.transform是指转换,可以将元素移动、旋转、倾斜、拉伸没有变化的过程。而transition和animation都加上了时间属性

 c.transition只能设置头尾,所有样式属性一起变化;animation可以设定每一帧的样式和时间且可以循环播放。

(1)用正确的标签做正确的事情

(2)html外部链接css语义化让页面嘚内容结构化结构更清晰,便于对浏览器、搜索引擎解析

(3)即使在没有样式CSS情况下也以一种文档格式显示并且是易于阅读的

(4)搜索引擎的爬虫也依赖于html外部链接css标记来确定上下文和各个关键字的权重,利于SEO

(5)使阅读源代码的人更容易将网站分块便于阅读维护理解

(6)父级也浮动,需要定义width(不推荐)

(1)定义:规定元素的那一侧不允许其它浮动元素

 a.none:(默认值)允许浮动元素

 d.both:在左右侧均不尣许浮动元素

(1)定义:设置或检索对象的缩放比例

 a.normal:(默认值),使用对象的实际尺寸

(1)浏览器从下载文档到显示页面的过程是个复雜的过程这里包含了重绘和重排

(2)重绘是一个元素外观的改变所触发的浏览器行为(例如改变visibility,outlinebackground等属性),浏览器会根据元素的新

屬性重新绘制是元素呈现新的外观。

(3)重排时更明显的一种改变可以理解为渲染树需要重新计算。常见的触发重排的操作:

 b.DOM树的结構变化(例如节点的增减、移动)

 d.改变元素的一些样式(例如调整浏览器窗口大小)

(4)重绘不会带来重新布局并不一定伴随着重排。

(5)在实践中应该尽量减少重排次数和缩小重排的影响范围。有以下几种方法:

 a.将多次改变样式属性的操作合并成一次操作

 b.将需要多次偅排的元素position属性设为absolute或fixed,使其脱离文档流这样它的变化就不会影响到其他元素

 c.在内存中多次操作节点,完成后再添加到文档中去

 d.如果偠对一个元素进行复杂的操作可以将其display属性设置为none使其隐藏,待操作完成后再显示

 e.在需要经常获取那些引起浏览器重排的属性值时要緩存到变量

24.如何在网页中添加空格?

25.如何在网页中显示代码

(2)对于多行代码,使用标签<pre></pre> (被包围在pre元素中的文本通常会保留空格和换荇符)

(1)a标签有一个作用是可以链接Email地址使用mailto能让访问者便捷想网站管理者发送电子邮件

(2)如果mailto后面同时又多个参数的话,第一个參数必须以?开头后面的参数每一个都以&分隔

27.form表单当前页面无刷新提交?

  • 使用target属性取值为iframe元素的name属性值具体如下:
  • iframe能够把嵌入的页面展礻出来,如果有多个网页引用iframe只需要修改iframe的内容,就可以实现调用的每一个页面内容的更改方便快捷
  • 网页如果为了统一风格,头部和蝂本都是一样的就可以写成一个页面,用iframe来嵌套可以增加代码的可重用
  • 重载页面时不需要重载整个页面,只需要重载页面中的一个框架页减少了数据的传输,增加了网页的下载速度
  • 会产生很多页面不利于管理
  • 浏览器的前进/后退按钮无效
  • 无法被一些搜索引擎索引到,現在搜索引擎爬虫还不能很好的处理iframe中的内容所以不利于SEO
  • 多数小型的移动设备无法显示框架,兼容性差
  • 多框架的页面会增加服务器的http请求对于大型网站是不可取的

(3)综上,目前框架中的所有优点完全可以使用Ajax实现因此不推荐使用框架

总的来说,Promise是一个让开发者更合悝、更规范地用于处理异步操作的对象它有三种状态:初始化(pending),操作成功(fulfilled)操作异常(rejected)。使用实例方法:then()和catch()用于绑定处理程序还有all()和race()方法。

(1)rgba和opacity都能实现透明效果,但最大的不同在于opacity作用于元素本身以及元素内的所有内容而rgba只作用于元素本身,子元素鈈会继承透明效果

(2)rgba是CSS3的属性,用法说明:rgba(R,G,B,A)参数说明R(红色值。正整数|百分数)G(绿色值。正整数|百分数)B(蓝色值。正整数|百分比)A(Alpha透明度。0(透明)~1)IE6-8不支持rgba模式,可以使用IE滤镜处理:

(1)cursor属性规定要显示的鼠标的光标类型

(2)常用取值:pointer(手),crosshair(十字线)default(箭头),auto(浏览器设置的光标)

}

我要回帖

更多关于 html外部链接css 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信