CSS样式优先级

CSS样式优先级

层叠性和继承性导致优先级问题

CSS样式有时会有冲突的情况,此时就要通过一定的规则来判断哪一条样式生效。

样式加载优先级

加载生效:行内样式 > 内部样式 > 外部样式 > 导入样式。

原则:距离远近原则

继承性规则

  1. 最近的祖先样式优先级比其他祖先样式高。
  2. 直接样式比祖先样式优先级高。

祖先样式就是继承下来而自身没有的样式,直接样式就是一个标签本身拥有的属性。

div{
    font-size:40px;
}
p{
    color:red;
}
<div><p>123<p><div>
针对123的字号属性,属于祖先样式,颜色属性属于直接样式。

选择器优先级的计算

通过选择器权值进行计算自身属性优先级。

权值表:
标签选择器                 权值:1
伪元素选择器或伪对象选择器    权值:1
类选择器                   权值:10
属性选择器                  权值:10
id选择器                   权值:100
其他选择器(如通配选择器)     权值:0

例子:

div p{
    font-size:40px;
}
//权值=1+1
div{
    font-size:20px;
    background-color:red;   
}
//权值=1
#box1{
    background-color:yellow;
}
//权值=100
.box1{
    background-color:blue;
}
//权值=10

在这里插入图片描述

出现冲突时会根据权值来决定是哪个选择器的样式生效。

如果权值相同,则后定义的样式会覆盖前定义的样式。

p{
    font-size:40px;
    font-size:20px;
}
//此时字体则为20px;
特殊情况

!improtant具有最高优先级,但是不推荐使用!

div{
    background-color:red !important;
}
#box1{
    background-color:yellow;
}
//此时类选择器的权值为100,大于标签选择器,但是因为标签选择器中样式有!important属性。则应用div选择器中的样式。
//!important具有最高优先级

**注意:**继承性规则比选择器优先规则优先级高。

例子:

在这里插入图片描述

通过计算,选择器优先级相同,本来字体应该应用div的40px样式。但是由于继承性规则2,直接样式比祖先样式优先级高。p本身自带font-size属性,所以就不用div(祖先)的样式。

如有错误或者建议,欢迎大佬指正!

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
HTML的CSS样式优先级是指当多个CSS规则同时应用到同一个元素上时,决定哪个规则的样式显示的规则。CSS样式优先级到低的顺序如下: 1. 内联样式(Inline Style):直接写在HTML元素的style属性中的样式具有最优先级。例如: ```html <p style="color: red;">这是红色文字</p> ``` 2. 内部样式表(Internal Style Sheet):在HTML文档头部的`<style>`标签中定义的样式表具有次优先级。例如: ```html <head> <style> p { color: blue; } </style> </head> <body> <p>这是蓝色文字</p> </body> ``` 3. 外部样式表(External Style Sheet):通过`<link>`标签引入的外部CSS文件具有比内部样式表低的优先级。例如: ```html <head> <link rel="stylesheet" href="styles.css"> </head> <body> <p>这是从外部样式表定义的样式</p> </body> ``` 4. 浏览器默认样式(Browser Default Styles):浏览器默认给定的样式是最低优先级的。如果没有定义任何样式,元素将应用浏览器默认样式。 5. 选择器特殊性(Selector Specificity):如果多个规则都是通过相同的选择器选中同一个元素,那么会根据选择器的特殊性来决定优先级。特殊性的计算规则是:ID选择器的特殊性最,类选择器和属性选择器次之,标签选择器和伪类选择器再次之,通用选择器和伪元素选择器最低。例如: ```html <style> p { color: red; } .my-class { color: blue; } </style> <p class="my-class">这个段落的颜色将是蓝色,因为类选择器的特殊性比标签选择器</p> ``` 需要注意的是,当样式优先级相同时,后定义的样式会覆盖前面定义的样式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FlowerHeap

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值