• css的特殊性笔记总结


    css 的特殊性也叫做css的权重。

        在css的选择器中,不同的选择器有不同的优先权也就是特殊性。选择器的特殊性由选择器本身的组件确定。特殊性值得表述为4个部分,如:0,0,0,0.

                (1)对于选择器中给定的各个ID属性值,加0,1,0,0。

                (2)对于选择器中给定的各个类属性值、属性选择或伪类,加0,0,1,0。

                (3)对于选择器中给定的各个元素和伪类,加0,0,0,1。

                (4)结合符合通配符选择器对特殊性没有任何贡献,也即是0,0,0,0。

                (5)继承的值根本没有特殊性,也就比0,0,0,0还要低。

           

      css解析时,都是从右到左解析选择器的,最右边的选择器越具体,其效率越高。通常#ID和.class前面不应加累赘的标签,否则影响到效率和权重。

     按照权重和来源排序

           在声明权重方面要考虑5级。权重由大到小的顺序依次为(重要声明是拥有!important):

                (1)读者的重要声明

                (2)创作人员的重要声明

                (3)创作人员的正常声明

                (4)读者的正常声明

                (5)用户代理声明

             如果两个规则中的权重、来源和特殊性完全相同,那么在样式表中后出现的一个会胜出.

           css2.1的层叠规则:

               (1)找出所有相关的规则,这些规则都包含与一个给定元素匹配的选择器。

               (2)按照显式权重对应用到该元素的所有声明排序。标志!important的规则的权重要高于没有!important标志的规则。

               (3)按照来源对应用到给定元素的所有声明排序。共有3种来源,创作人员,读者和用户代理。正常情况下,创作人员 > 读者模式 > 用户代理的默认样式。

               (4)按照特殊性对应用到给定元素的所有声明排序。有较高特殊性的元素权重要大于有较低的特殊性的元素。

               (5)按照出现的顺序应用到给定元素的所有声明排序。一个声明在样式表或文档中越后出现,它的权重就越大。如果样式表中右导入的样式表,一般认为出现在导入样式表中的声明在前,主样式表中的所有声明在后。

    ps:参考《css权威指南》

  • 相关阅读:
    app缓存设计-文件缓存
    设计模式-模板方式
    设计模式-观察者模式
    java 类加载顺序
    Java项目添加log4j日志文件错误记录
    如何在eclipse中配置反编译工具JadClipse
    eclipse反编译插件jadClipse安装使用教程
    StringUtils工具类的isBlank()方法使用说明
    SLF4J: Failed to load class的问题及解决
    GitHub的Fork 是什么意思
  • 原文地址:https://www.cnblogs.com/hanbingljw/p/3537349.html
Copyright © 2020-2023  润新知