谈谈CSS层叠优先级

CSS样式是HTML文档的外观优化,最近学习CSS发现它的样式层叠方式没那么简单,于是写了这篇文章做一个小小的总结(目前为边学习边写博客,故如有错还请指出,多谢)

一、样式编写的位置

在HTML文档中,可分为两种方式定义样式:

第一种:作者样式

作者样式又分为三种:

1.元素style属性

style是HTML中的一个全局属性,也就是说所有元素都能使用,下面给出一例:

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
</head>
<body>
    <h1 style="background:blue">style属性</h1>
</body>
</html>
<!DOCTYPE HTML>

我用谷歌打开的运行结果:

2.文档<style></style>元素

该元素在html文档中的父元素为<head></head>,内容为css代码,能作用于该html文档。

css对html元素起作用的方式目前我所知有四种(属于css知识):

这四种都属于选择器的编写方式

å:选择器前加上所作用的元素种类

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
    h1{
        background: blue;
        color:white;
    }
    </style>
</head>
<body>
    <h1>&#60;style&#62;&lt;/style&gt;元素</h1>
</body>
</html>
<!DOCTYPE HTML>

运行结果如下:

ß:选择器前加上“.“表示选择对应class属性的元素

class属性也是一个全局属性,对元素本身没有直接影响,可被css和JavaScript使用

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
    .head{
        background: blue;
        color:white;
    }
    </style>
</head>
<body>
    <h1 class="head">&#60;style&#62;&lt;/style&gt;元素</h1>
</body>
</html>
<!DOCTYPE HTML>

 运行结果:

∂:在元素前加上“#”表示选择对应id属性的元素

id属性也是一个全局属性,但特点是整个html文档所有元素id属性值不能重复,也就是每一个与元素的id属性值是独一无二的

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
    #head{
        background: blue;
        color:white;
    }
    </style>
</head>
<body>
    <h1 id='head'>&#60;style&#62;&lt;/style&gt;元素</h1>
    <h1 id='not head'>other</h1>
</body>
</html>
<!DOCTYPE HTML>

运行结果:

3.文档通过<link/>元素引入外部css样式表

----css.css----
#head{
    background :blue;
    color: white;
}



----styles.html----
<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <link rel="stylesheet" tyle="text/css" href="css.css"/>
</head>
<body>
<h1 id='head'>&#60;style&#62;&lt;/style&gt;元素</h1>
<h1 id='not head'>other</h1>
</body>
</html>
<!DOCTYPE HTML>

使用方法就是把style元素中的内容单独写到css文件中

运行结果于上相同

这三种方式可以同时使用,如果它们定义的属性冲突了,又该如何决定实际的属性值呢? 

比如说:

----style.css----
p{
    background: blue;
}



----page.html----
<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <!-- link元素 -->
    <link rel="stylesheet" type="text/css" href="style.css"/>
    <!-- style元素 -->
    <style>
        p{
            background: cyan;
        }
    </style>
</head>
<body>
<!-- style属性 -->
<p style="background:red">paragraph</p>
</body>
</html>
<!DOCTYPE HTML>

运行一下就知道结果了!

显而易见,浏览器选择了元素的style属性 

其根本原因是这样滴:

对于这三种作者样式,其优先级关系为:style属性>style元素>link元素

当某一个元素的某一种样式属性出现冲突时,按照以上的顺序查找并决定最终样式

但如果在同一层优先级中又出现了冲突属性,又该如何决定最终样式呢?

对于style属性,一般不会出现冲突,除非你故意重复编写一种属性的样式(不要乱来呀!)这里就不讨论了

对于style元素(内的css代码)或单独的link元素(css文件内的代码),若多个类的属性冲突了,并且在html文档中有一个元素class属性包含了这多个类会怎么样呢?

如下代码以style元素为例:

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
        .head1{
            background: cyan;
        }
        .head2{
            background: yellow;
        }
    </style>
</head>
<body>
<p class="head1 head2">paragraph</p>
</body>
</html>
<!DOCTYPE HTML>

运行结果:

可以看到,系统选择了编写位置靠后的head2类的属性。

这里得到结论:当属性选择的选择器优先级程度和具体化程度相同时,以编写位置靠后(版本最新)者属性为主

那么如果在id选择器和class选择器中出现属性冲突呢?

如下代码:

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
        #head1{
            background: cyan;
        }
        .head2{
            background: yellow;
        }
    </style>
</head>
<body>
<p class="head2" id="head1">paragraph</p>
</body>
</html>
<!DOCTYPE HTML>

 运行结果:

 

 系统选择了id选择器

我们可以得到结论:当选择器优先级相同时,具体度高的选择器优先级高于具体度低的。

在这里id选择器具体度无疑是最高的,高于class选择器,即使id选择器编写位置更靠前。

具体度大小关系:元素选择器>class选择器>id选择器

后面两者关系已经证实了,下面我们验证一下前两者:

代码:

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
        .head2{
        background: yellow ;
        }
        p{
            background: red;
        }
        
    </style>
</head>
<body>
<p id="head1" class="head2">paragraph</p>
</body>
</html>
<!DOCTYPE HTML>

运行结果 :

 

但css给出了一种打破原有样式的语法:“!important”语法

使用方法:

<!DOCTYPE HTML>
<html lang="ch">
<head>
    <meta charset="UTF-8">
    <title>styles</title>
    <style>
        .head2{
        background: yellow ;
        }
<!--直接在“red”之后用添加上“!import" -->
        p{
            background: red !important;
        }

    </style>
</head>
<body>
<p id="head1" class="head2">paragraph</p>
</body>
</html>
<!DOCTYPE HTML>

运行结果:

 在冲突的所有属性中,带有!import的属性优先级将直接高于其他所有没带!important的属性。再从这些剩下带!important的属性中判断优先级

第二种:用户样式:

这种样式为浏览器为用户提供的一种自定义样式的接口,也是用css编写的,特点是它是用户特异的而非网页或浏览器特异的。在一个我不清楚的文件夹下可以编写这个css文件(书中只提到Chrome浏览器的目录是:Default/User StyleSheets/Custom.css)。

第三种:浏览器样式:

这是元素不手动设置样式时浏览器应用在元素上的默认样式,具体实现取决于具体的浏览器。知识所限,这里点到为止。

优先级:作者样式>用户样式>浏览器样式

总结:

层叠顺序先按优先级,后按具体度

优先级:style属性>style元素>link外部文件>用户样式>浏览器样式

具体化:id>class>元素

!important使得优先级比没有!important的更高

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTMLCSS样式优先级是指当多个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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值