比如:如果设置了【:first-child或者:last-child,:nth-child()】等这种选择器,会采用选择器的css;如果设置了【!important】会采用有这个的css,就算是写在div里面的也没有这个级别高(但不是万能的,有的可以设置有的不行,列出来太多了,记着也麻烦,最简单的记忆方式就是写完在浏览器中F12,如果划横线就是不好使)
width:10px !important;意思是设置成最高级别,不管先后都会采用这个css,如果有两个这种代码会采用最后一个。
以下是优先级设置顺序:
1、width:10px;
2、width:10px !important;
3、:first-child{width:10px;}
4、:first-child{width:10px !important;}
优先级顺序为4>2>3>1,如果是同级别情况下会就近选择,就是选择最后一个
这属于"多重样式(Multiple Styles)"
多重样式(Multiple Styles):如果外部样式、内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况。
一般情况下,优先级如下:
(外部样式)External style sheet <(内部样式)Internal style sheet <(内联样式)Inline style,例如:
<head><style type="text/css">
/* 内部样式 */
h3{color:green}
</style>
<!-- 外部样式 style.css -->
<link rel="stylesheet" type="text/css" href="style.css"/>
<!-- 设置:h3{color:blue} -->
</head>
<body>
<h3>测试!</h3>
</body>
在选择器的情况下:
如图:
解释:
1. 内联样式表的权值最高 1000;
2. ID 选择器的权值为 100
3. Class 类选择器的权值为 10
4. HTML 标签选择器的权值为 1
利用选择器的权值进行计算比较,示例如下:
<html><head>
<style type="text/css">
#redP p {
/* 权值 = 100+1=101 */
color:#F00 /* 红色 */
}
#redP .red em {
/* 权值 = 100+10+1=111 */
color:#00F /* 蓝色 */
}
#redP p span em {
/* 权值 = 100+1+1+1=103 */
color:#FF0/*黄色*/
}
</style>
</head>
<body>
<div id="redP">
<p class="red">red
<span><em>em red</em></span>
</p>
<p>red</p>
</div>
</body>
</html>
结果:<em> 标签内的数据显示为蓝色。
CSS 优先级法则:
A 选择器都有一个权值,权值越大越优先;
B 当权值相等时,后出现的样式表设置要优于先出现的样式表设置;
C 创作者的规则高于浏览者:即网页编写者设置的CSS 样式的优先权高于浏览器所设置的样式;
D 继承的CSS 样式不如后来指定的CSS 样式;
E 在同一组属性设置中标有“!important”规则的优先级最大;示例如下:
<html><head>
<style type="text/css">
#redP p{
/*两个color属性在同一组*/
color:#00f !important /* 优先级最大 */
color:#f00
}
</style>
</head>
<body>
<div id="redP">
<p>color</p>
<p>color</p>
</div>
</body>
</html>