从CSS代码存放位置看权重优先级:内嵌样式 > 内部样式表 > 外联样式表。其实这个基本可以忽视之,大部分情况下CSS代码都是使用外联样式表。
从样式选择器看权重优先级:important > 内嵌样式 > ID > 类 > 标签 | 伪类 | 属性选择 > 伪对象 > 继承 > 通配符。
- important的权重为1,0,0,0
- ID的权重为0,1,0,0
- 类的权重为0,0,1,0
- 标签的权重为0,0,0,1
- 伪类的权重为0,0,1,0
- 属性的权重为0,0,1,0
- 伪对象的权重为0,0,0,1
- 通配符的权重为0,0,0,0
<html> <head> <style type="text/css"> #left{color:black!important;} /*1,1,0,0*/ #container #left{color:red;} /*0,2,0,0*/ #left{color:green!important;} /*1,1,0,0*/ .container #left{color:blue;} /*0,1,1,0*/ </style> </head> <body> <div class="container" id="container"> <span id="left">这到底是什么颜色啊?</span> </div> </body> </html>
<!-- 2个#left的权重都是1,1,0,0 这个时候就采用最后定义原则,所以最后输出的姿态是绿色的。-->