CSS选择器相关以及CSS选择器的优先级
来源:互联网 发布:淘宝网络兼职可信吗 编辑:程序博客网 时间:2024/04/25 11:38
首先,当我们给css中的选择器设定样式后,有一些属性并没有起作用。通过FireBug查看发现一些属性被覆盖了。那么CSS的优先级是如何的呢?
在CSS中,基本选择器诸如 id选择器,class类选择器,还有标签选择器。组合使用的时候,又有后代选择器和群组选择器。
语法:
id选择器:#id
<style type="text/css">#mydiv{color: red;}</style><body><div id="mydiv"><p>文字相关</p></div></body>
类选择器:.class
<style type="text/css">.cls{color: red;}</style><body><div class="cls"></div></body>
标签选择器:div, p span等。
<style type="text/css">.cls{color: red;}</style><body><div><p>文本</p></div></body>后代选择器:
<style type="text/css">div .mytext{color: red;}</style><body><div><p class="mytext">文本</p></div></body>
群组选择器:
<style type="text/css">div .mytext,p{color: red;}</style><body><div><p class="mytext">文本</p><span>哈哈哈哈哈</span></div></body>以上共五种选择器。
选择器的优先级:
以下面的代码为例
<style type="text/css">#mydiv span{color: red;}span {color: black;}</style><body><div id="mydiv"><span> 文本内容</span></div></body>
执行结果后,文本是红色的。也就是说 上面的css样式覆盖了下面的样式。
出现这个结果的原因是 下面的优先级不够。
优先级如何确定呢?
一般给定id选择器的优先级为100 class选择器优先级为 10 标签选择器优先级为 1
当我们遇到诸如此类:
#mydiv p span .block.block spanspan a .red.wrapa#div
选择器优先级可以这么算:
#mydiv p span .block 100+1+1+10 = 112.block span 10+1 = 11span a .red 100+1+10 = 111.wrap 10a 1#div 100
优先级不言而喻。
优先级使用以上已经介绍清楚,那么 如何根据情况选择最适合的选择器呢?
- 最常用类选择器
- id最好使用在页面只出现一次的标签内。
- li、td、dd等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器 .xx li/td/dd {} 的方式选择。
- HTML标签中用style引入的css样式的优先级1000 但是不提倡。因为不符合解耦性。
那么浏览器是如何针对css选择器来查找元素的?
浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css:<style> DIV#divBox p span.red{color:red;} ><style> <body> <div id="divBox"> <p><span>s1</span></p> <p><span>s2</span></p> <p><span>s3</span></p> <p><span class='red'>s4</span></p> </div> </body>浏览器的查找顺序如下:先查找html中所有class='red'的span元素,找到后,再查找其父辈元 素中是否有p元素,再判断p的父元素中是否有id为divBox的div元素,如果都存在则匹配上。
如何让自己的css样式更加简洁高效?
css高效的原理主要是减少浏览器的查找
类选择器前不用标签选择器 特例:多个标签的类选择器相同 但是要求样式有些不一样。
id选择器前不用标签选择器。
如:
a .redb .red尽量减少层级关系
如:
#div p span .red
应该使用:.red使用class选择器代替层级关系。
如:
#mydiv p span a
{<span style="font-family: Arial, Helvetica, sans-serif;"> display: block;</span>
}
替代:.block { display: block;}
0 0
- CSS选择器相关以及CSS选择器的优先级
- CSS选择器以及优先级
- css选择器&选择器的优先级
- CSS选择器的优先级
- CSS选择器的优先级
- CSS 选择器的优先级
- css选择器的优先级
- CSS的选择器,优先级
- CSS选择器的优先级
- css选择器的优先级
- CSS选择器的优先级
- css选择器的优先级
- css选择器的优先级
- css 引入方式,选择器,选择器的优先级
- CSS选择器分类、选择器优先级以及CSS优化原则
- CSS选择器的优先级设定
- css中选择器的优先级
- css选择器的优先级比较
- 如何在iterm2中设置自动远程登录(附跳板机攻略)
- leetCode88:Merge Sorted Array
- 2016,我要前进
- 局域网ip
- 最常用的20个监控Linux系统性能的命令行工具
- CSS选择器相关以及CSS选择器的优先级
- 258. Add Digits
- gcc 编译.c文件的编译过程
- 15年摄像头传感器
- 如何一步步拿到伐册 book申请http://www.bosshr.com/shownews_47767.html
- python学习(一)变量和数据类型
- C#设计模式_单例模式
- spark python 线性回归
- 关于jps命令-bash: jps: command not found 解决方案