CSS 的层叠规则说明
所属分类:
网页制作 / CSS
阅读数:
1867
收藏 0赞 0分享
整个过程
查找competing rule集。
对competing rules进行排序;
对元素,应用sorted rules中的属性(层叠过程,高优先级的在上面,覆盖了下面低优先级的属性)
最后渲染,考虑继承值(也是个层叠过程)和默认值, 再做属性值转换。
原则就是 general ---> special
查找阶段
遍历所有css rule, 找出有效的rule.
Rules 排序
先 selector group,后 position group
selector groups:(从高到低)
1. !important 最高
2. inline style
3. id selector
4. class and pseudo-class pseudo-element, attribute selector
5. element selector
6. * universal selector
先看群组级别,
最高群组相同的话, 再看本群组的积分(多少个),
如果数量相同,就要看更低的群组,重复;
如果还相同,就要看 postion group:
position group:
1. <style> css rule</style>
2. <style> @import css; <style>
3.<link />
4. <link /> ----> @import css; 外部文件中的@import css中的rule
5. user setting style ,如果在这里的样式使用了 !important那么就是最高的等级了(比文档中的!importance还高,反强奸)
6. user agent css 浏览器默认样式
先看位置群组级别,如果相同就看在文档中出现的顺序(后面覆盖前面)
这样就为 元素 获得了所有的rule中属性值,最后建立了 doc 的css属性树。
渲染阶段
渲染的时候,取元素的已有css属性值出来渲染;
对于CSS属性树中没有的属性,如果这些属性可以被继承,那么就考虑元素的祖父结点中的属性值;
如果还是不能确定属性值, 这时使用就使用属性的默认值。
上面的就把元素的所有值确定了,但因为有些值是相对值( 10%, 2ex等),这时需要把相对值计算出 绝对值, 不是所有值的是有效的,这时又要转换成实际值(数值取整等)。
最后浏览器用这些 actual attribute value 去渲染。
其它:
视觉继承(z序): 子元素在父元素上面,后面的元素在前面的元素的上面,默认背景是透明。
测试发现:*.class == .class
前端设计师需要了解的9个问题
这篇文章主要介绍了前端设计师需要了解的9个问题以及注意事项,非常的实用,是篇非常不错的文章,这里推荐给大家
收藏 0赞 0分享
CSS强制性换行的方法区别详解
自动换行问题,正常字符的换行是比较合理的,而连续的数字和英文字符常常将容器撑大,挺让人头疼,下面介绍的是CSS如何实现换行的方法对于div,p等块级元素正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的white-space:normal,当定义的宽度之后自动换行
收藏 0赞 0分享
CSS语义化命名方式及常用命名规则
本文搜集了一些CSS语义化命名方式以及命名规则。如有错误或不妥之处,敬请指出,欢迎你提出更好的建议,加插更多的命名规范。
收藏 0赞 0分享
ul li内容宽度的问题的解决方案
在IE6下只要我设置LI的宽度为auto,不论LI里面的内容多长,LI的宽度始终是100%,即UL的宽度(这里我已经写死了UL的宽度)。设置max-width也没用。高手们,在IE系列浏览器中如何使LI的宽度真正的随着内容增长而增长呢?像FF那样。
收藏 0赞 0分享
html5+css3气泡组件的实现
本文是html5+css3系列教程的第一篇,给大家讲述html5+css3实现气泡组件,讲解的十分的详细,这里推荐给大家,希望对大家能有所帮助
收藏 0赞 0分享
html5+css3之CSS中的布局与Header的实现
本文从CSS3的布局(CSS的布局的演化、CSS3盒模型-box-sizing、float布局中的bfc、Flexbox简介)Header布局的实现(float实现布局、Header js的实现)向我们展示了HTML5与CSS3的魅力。
收藏 0赞 0分享
CSS3提交意见输入框样式代码
这个提交意见输入框,结构使用到了table,样式用的css3,包含了多方面的知识,比较适合新手朋友们
收藏 0赞 0分享
查看更多