CSSCSS 特性 ③ ( CSS 优先级 | 优先级引入 | 选择器基本权重 )

Posted 韩曙亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSSCSS 特性 ③ ( CSS 优先级 | 优先级引入 | 选择器基本权重 )相关的知识,希望对你有一定的参考价值。

文章目录





一、CSS 优先级




1、优先级引入


定义 CSS 样式时 , 可能出现 多个 类型相同的 规则 定义在 同一个元素上 ,

  • 如果 CSS 选择器 相同 , 执行 CSS 层叠性 , 根据 就近原则 选择执行的样式 , 如 : 出现两个 div 标签选择器 , 都设置 color 文本颜色 ;
	<style>
		div 
			color: red;
			font-size: 30px;
		

		div 
			color: blue;
		
	</style>
  • 如果 CSS 选择器 不同 , 则需要考虑 CSS 优先级 问题 , 需要计算对应的 选择器 权重 ;

2、选择器基本权重


CSS 选择器选择器优先级 - 权重计算
继承父标签的样式 , * 通配符选择器0,0,0,0
标签选择器0,0,0,1
类选择器,链接伪类选择器0,0,1,0
ID 选择器0,1,0,0
标签的行内样式 style 属性1,0,0,0
样式后添加 !important权重无穷大
  • 继承父类样式 选择器 , 权重 0,0,0,0 ;
		/* 0. 继承父类样式 权重 0,0,0,0 */
		body 
			color: red;
		
  • 通配符选择器 * , 权重 0,0,0,0 ;
		/* 0. 通配符选择器 权重 0,0,0,0 */
		* 
			color: red;
		
  • 标签选择器 , 权重 0,0,0,1 ;
		/* 1. 标签选择器 权重 0,0,0,1 */
		div 
			color: pink
		
  • 类选择器 , 权重 0,0,1,0 ;
		/* 2. 类选择器 权重 0,0,1,0 */
		.one 
			color: blue;
		
  • ID 选择器 , 权重 0,1,0,0 ;
		/* 3. ID 选择器 权重 0,1,0,0 */
		#two 
			color: green;
		
  • 行内样式表 , 权重 1,0,0,0 ;
	/* 4. 行内样式表 权重 1,0,0,0 */
	<div class="one" id="two" style="color: purple;"> 选择器权重 </div>
  • 任何选择器中 样式后 添加 !important 权重会被提升为无穷大 , 即使在最低级的 标签选择器样式后添加 !important , 其样式的权重也会被强行提高到最高级 , 权重无穷大 ;
		/* 5. 任何选择器中 样式后 添加 !important 权重最高 */
		div 
			color: pink!important;
		

3、完整代码示例


完整代码示例 :

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		/* 0. 继承父类样式 权重 0,0,0,0 */
		body 
			color: red;
		
		/* 0. 通配符选择器 权重 0,0,0,0 */
		* 
			color: red;
		
	
		/* 1. 标签选择器 权重 0,0,0,1 */
		div 
			color: pink
		
		
		/* 2. 类选择器 权重 0,0,1,0 */
		.one 
			color: blue;
		
		
		/* 3. ID 选择器 权重 0,1,0,0 */
		#two 
			color: green;
		
		
		/* 4. 行内样式表 权重 1,0,0,0 */
		
		/* 5. 任何选择器中 样式后 添加 !important 权重最高 */
		div 
			color: pink!important;
		
	</style>
</head>
<body>
	/* 4. 行内样式表 权重 1,0,0,0 */
	<div class="one" id="two" style="color: purple;"> 选择器权重 </div>
</body>
</html>

展示效果 : 最终展示的效果是 color: pink!important; 效果 , 其权重无穷大 ;

以上是关于CSSCSS 特性 ③ ( CSS 优先级 | 优先级引入 | 选择器基本权重 )的主要内容,如果未能解决你的问题,请参考以下文章

CSSCSS样式的优先级

CSSCSS样式的优先级

CSSCSS三大特性

CSSCSS 层叠样式表 ③ ( CSS 引入方式 - 外链式 | CSS 样式规则 )

CSSCSS2和CSS3选择器总结(全部选择器种类及其优先级)

CSSCSS 特性 ② ( CSS 继承性 )