• CSS选择器的特殊性


      在我们为元素添加样式的时候,或多或少会出现一个元素会有几个不同规则的样式。有#id的,有.class,直接标签元素的,还有各种组合起来的选择器。那CSS到底如何解决这些冲突呢,我们这次专门来探讨一下。

      CSS也称层叠样式,层叠(cascade)也就是说,将重复定义的样式,先通过重要度的筛选,再通过一定的规则,重新排列覆盖。而这个规则就是,选择器的特殊性。(重要度就不详细说明了,一般认为!important>行内样式>内联样式表>外联样式表>浏览器默认样式)

      特殊性

    每种选择器都会默认分配一个数值,然后将一个规则的选择器数值相加,计算出其特殊性。

      选择器的特殊性有4个等级,a,b,c,d(正常来说,一个规则的选择器应该不会超过10个,这样我们可以转化成以10为基数计算特殊性)

    • a:行内样式,那么a = 1 。
    • b:ID选择器的总数 。
    • c:类、伪类和属性选择器的总数。
    • d:类型选择器和伪元素选择器总数。

    或许这样说,有点难以理解,我们可以举栗子。

    style = ""             ------------ 特殊性:1000
    
    #warp #content{}       ------------ 特殊性:200
    
    #content .smClass{}    ------------ 特殊性:110
    
    div.#content{}         ------------ 特殊性:101
    
    #content{}             ------------ 特殊性:100
    
    p.class1.class2        ------------ 特殊性:21
    
    p.class1               ------------ 特殊性:11
    
    .class                 ------------ 特殊性:10
    
    div p{}                ------------ 特殊性:2
    
    p{}                     ------------ 特殊性:1  
    

     当然,若一个元素的两套规则特殊性相等,则后定义的规则优先。

    通过这样一番描述,相信大家对选择器的特殊性有了一定的了解。所以当出现了一些样式定义却未显示的情况时,要看一下是否有样式覆盖的情况,合理使用样式表选择器的优先级。

    大家赶紧动手去试试吧!

    (若有不准确或错误的地方,希望大家指出,我会赶紧修改)

  • 相关阅读:
    openstack running 2
    openstack running 3
    好东西哟 XD
    Linux 上課用細部調整(转)
    openstack swift install 1
    Spring初识(通过小实例清晰认识Spring)
    Windowphone中如何将项目导出为模板
    WP8点击桌面图标快速恢复应用
    WindowsPhone8中SaveSong方法将音乐文件转存到音乐库中
    Windows Phone 数据绑定之UI Element Binding
  • 原文地址:https://www.cnblogs.com/YikaJ/p/3998364.html
Copyright © 2020-2023  润新知