• CSS的优先级问题


      所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序。既然样式有优先级,那么就会有一个规则来约定这个优先级,而这个“规则”就是重点。

      样式表允许以多种方式规定样式信息。样式可以规定在单个的 HTML 元素中,在 HTML 页的头元素中,或在一个外部的 CSS 文件中。甚至可以在同一个 HTML 文档内部引用多个外部样式表。当同一个 HTML 元素被不止一个样式定义时,会使用哪个样式呢?

    一般而言,所有的样式会根据下面的规则层叠于一个新的虚拟样式表中,其中数字 4 拥有最高的优先权。

    1. 浏览器缺省设置
    2. 外部样式表
    3. 内部样式表(位于 <head> 标签内部)
    4. 内联样式(在 HTML 元素内部)

      因此,内联样式(在 HTML 元素内部)拥有最高的优先权,这意味着它将优先于以下的样式声明:<head> 标签中的样式声明,外部样式表中的样式声明,或者浏览器中的样式声明(缺省值)。这只是一个大方面的优先级,在前面文章中我们讲过CSS有很多选择器,那么对于同种样式的CSS,各个选择器的优先级又是如何呢?

      我们将某一个CSS看成一个三位数,通过比较数字的大小来获取优先级的高低,那么就会相当简单。在这里可以通过下面的规则来定义各个选择器对应的数字。

    1. 百位数是该选择器上的id的数量的总和;
    2. 十位数是用在该选择器上的其它属性选择器和伪类的总和。这里包括class (.example) 和属性选择器(比如 li[id=red]);
    3. 个位数是计算元素(就像table、p、div、*等等)和伪元素(就像:first-line等);
    4. 如果两个选择器对应的数字相等,也就是具有同样的优先级,在样式表中后面的那个起作用。
    5. 标有"!important"的规则具有最高优先级,例如H1{color:black !importan; font-family:sans-serif},前景色被标为important,这个前景色具有很高的优先级。但是这种声明容易引起混乱,因此通常使用得较少。
    选择器 数值
    h1 {color:blue;} 1
    p em {color:purple;} 1 + 1 = 2
    .apple {color:red;} 10
    p.bright {color:yellow;} 1 + 10 = 11
    p.bright em.dark {color:brown;} 1 + 10 + 1 + 10 = 22
    #id316 {color:yellow} 100

    一般我们还可以通过浏览器的插件来查看,到底哪个CSS起作用,比如Firebug(Firefox)、Developer Tools(IE8)等。上面我们介绍到当优先级相同时,哪个CSS起作用取决于所处的位置,通常后面的CSS优先级要高。但是对于IE浏览器,具有相同数值的动态CSS取决于添加的顺序前后,而不是添加的位置前后;后添加的优先级要高。

  • 相关阅读:
    redis cluster 详解
    redis 数据占用内存大小分析
    java 中@RequestParam和@PathVariable
    git merge后,想恢复之前版本步骤
    Typescript中?? ?: ?. 都代表什么作用
    买卖股票的最佳时机系列问题
    最长递增子序列
    结构体统一说明
    Barcode Detection API All In One
    Learn Progressive Web Apps All In One
  • 原文地址:https://www.cnblogs.com/liontone/p/1931268.html
Copyright © 2020-2023  润新知