2025年3月18日 星期二 甲辰(龙)年 月十七 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > Html+Div+Css(前端)

CSS的声明优先级

时间:08-26来源:作者:点击数:38

优先级由高到低(高优先级则决定最终css显示的效果)

  1. 用户的重要声明(最大):!important
  2. 程序员写的重要声明: !important
  3. 内联(标签中的style直接写的那种)
  4. id选择器
  5. 类选择器、属性选择器、伪类
  6. 元素选择器和伪元素(例如:div{color:red})
  7. 通配符选择器,例如:*{width:200px}
  8. 继承父元素嵌套div这种,里面的可以继承外面标签的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.结合符对选择器特殊性没有一点贡献
  • 6.内联声明的特殊性都是1,0,0,0
  • 7.继承没有特殊性
  • 特殊性 1,0,0,0 大于所有以0开头的特殊性(不进位)
  • 选择器的特殊性最终都会授予给其对应的声明
  • 如果多个规则与同一个元素匹配,而且有些声明互相冲突时,特殊性越大的越占优势
  • 注意:id选择器和属性选择器
  • div[id="test"]0,0,1,1) 和 #test0,1,0,0
  • 重要声明
  • 有时某个声明比较重要,超过了所有其他声明,css2.1就称之为重要声明
  • 并允许在这些声明的结束分号之前插入 !important 来标志
  • 必须要准确的放置 !important 否则声明无效。
  • !important 总是要放在声明的最后,即分号的前面
  • 标志为 !important的声明并没有特殊的特殊性值,不过要与非重要声明分开考虑。
  • 实际上所有的重要声明会被浏览器分为一组,重要声明的冲突会在其内部解决
  • 非重要声明也会被分为一组,非重要声明的冲突也会在其内部解决
  • 如果一个重要声明与非重要声明冲突,胜出的总是重要声明
  • 继承
  • 继承没有特殊性,甚至连0特殊性都没有
  • 0特殊性要比无特殊性来的强
  • 来源
  • css样式的来源大致有三种
  • 创作人员
  • 读者
  • 用户代理
  • 权重:
  • 读者的重要声明
  • 创作人员的重要声明
  • 创作人员的正常声明
  • 读者的正常声明
  • 用户代理的声明
  • 层叠
  • 1.找出所有相关的规则,这些规则都包含一个选择器
  • 2.计算声明的优先级
  • 先按来源排序
  • 在按选择器的特殊性排序
  • 最终按顺序
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门