![详解CSS选择器_第1页](http://file3.renrendoc.com/fileroot_temp3/2022-5/7/b8979d77-d71b-4e2c-9ff5-cfc44a37640a/b8979d77-d71b-4e2c-9ff5-cfc44a37640a1.gif)
![详解CSS选择器_第2页](http://file3.renrendoc.com/fileroot_temp3/2022-5/7/b8979d77-d71b-4e2c-9ff5-cfc44a37640a/b8979d77-d71b-4e2c-9ff5-cfc44a37640a2.gif)
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、详解CSS选择器、优先级与匹配原理2010-09-1615:32polarislll9JavaEye我要评论(7)字号:T|T收藏文章就CSS选择器的优先级问题做了一些总结,严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。AD:2013大数据全球技术峰会低价抢票中作为一个Web开发者,掌握必要的前台技术也是很重要的,特别是在遇到一些实际问题的时候。这里给大家列举一个例子:给一个p标签增加一个类(class),可是执行后该class中的有些属性并没有起作用。通过Firebug查看,发现没有起作用的属性被覆盖了。这个时候突然意识到了CSS选择器的优先级问题,这里就CSS选择
2、器的优先级问题做了一些总结。51CTO推荐阅读:巧妙地使用CSS选择器选择器种类严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=""的方式,应该是CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。而一般人们将上面这几种方式结合在一起,所以就有了5种或6种选择器了。三种基本的选择器类型语法如下:标签名选择器,如:p,即直接使用HTML标签作为选择器。类选择器,如.polaris。ID选择器,如#polaris。注意,ID选择器跟类选择器有很大的不同:一
3、个页面内不能出现相同的ID;再就是ID也是后台开发人员会经常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合十分娴熟之后,这些都不会成为限制。扩展选择器后代选择器,如.polarisspanimg,后代选贼器实际上是使用多个选择器加上中间的空格来找到具体的要控制标签。群组选择器,如div,span,img,群组选择器实际上是对CSS的一种简化写法,只不过把有相同定义的不同选择器放在一起,省了很多代码。选择器的优先级别了解了各种选择器后,还有一个重要的知识点就是CSS选择器的优先级。这也就是为什么polaris会遇到文章开头的问题。举个简单的例子:1 <divclass=&
4、quot;polaris">2 <spanclass="beijixing">3 beijixing4 </span>5 <span>6 polaris7 </span>8 </div>如果已经把.polaris下面span内的字体设置成红色:9 .polarisspancolor:red;这时,如果要改变.beijixing的颜色为蓝色,用下面的命令是不能实现的:10 .beijixingcolor:blue;出现这种情况就是因为后一个命令的优先级不够,两条相互冲突的样式设置,浏览器只会执行优先级
5、较高的那个。那么选择器的优先级是怎么规定的呢?一般而言,选择器越特殊,它的优先级越高。也就是选择器指向的越准确,它的优先级就越高。通常我们用1表示标签名选择器的优先级,用10表示类选择器的优先级,用100标示ID选择器的优先级。比如上例当中.polarisspancolor:red;的选择器优先级是10+1也就是11;而.polaris的优先级是10;浏览器自然会显示红色的字。理解了这个道理之后下面的优先级计算自是易如反掌:11 div.testl.spanvar优先级1+10+10+112 span#xxx.songsli优先级1+100+10+113 #xxxli优先级100+1对于什么情
6、况下使用什么选择器,用不同选择器的原则是:第一:准确的选到要控制的标签;第二:使用最合理优先级的选择器;第三:HTML和CSS代码尽量简洁美观。通常:1、最常用的选择器是类选择器。2、li、td、dd等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器.xxli/td/dd的方式选择。3、极少的情况下会用ID选择器,当然很多前端开发人员喜欢header,footer,banner,conntent设置成ID选择器的,因为相同的样式在一个页面里不可能有第二次。在这里不得不提使用在标签内引入CSS的方式来写CSS,即:14 <divstyle=&q
7、uot;color:red">polaris</div>这时候的优先级是最高的。我们给它的优先级是1000,这种写法不推荐使用,特别是对新手来说。这也完全违背了内容和显示分离的思想。DIV+CSS的优点也不能再有任何体现。后代选择器的定位原则在这里介绍一下对于后代选择器,浏览器是如何查找元素的呢?浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如DIV#divBoxpspan.redcolor:red;,浏览器的查找顺序如下:先查找html中所有class二'red'的span元素,找到后,再查找其父辈元素中是否有p元素,再判断p的父元
8、素中是否有id为divBox的div元素,如果都存在则匹配上。浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css:15 <style>16 DIV#divBoxpspan.redcolor:red;17 Xstyle>18 <body>19 <divid="divBox">20 <pXspan>s1</spanX/p>21 <pXspan>s2</spanX/p>22 <pXspan>s3</spanX/p>23 &l
9、t;pXspanclass='red'>s4</spanX/p>24 </div>25 </body>如果按从左到右查找,哪会先查找到很多不相关的p和span元素。而如果按从左到右的方式进行查找,则首先就查找到spanclass二'red'的元素。firefox称这种查找方式为keyselector(关键字查询),所谓的关键字就是样式规则中最后(最右边)的规则,上面的key就是span.red。简洁、高效的CSS所谓高效的CSS就是让浏览器在查找style匹配的元素的时候尽量进行少的查找,下面列出一些我们常见的写CSS犯一些低效错误:不要在ID选择器前使用标签名一般写法:DIV#divBox更好写法:#divBox解释:因为ID选择器是唯一的,加上div反而增加不必要的匹配。不要再class选择器前使用标签名一般写法:span.red更好写法:.red解释:同第一条,但如果你定义了多个red,而且在不同的元素下是样式不一样,则不能去掉,比如你css文件中定义如下:26 p.redcolor:red;27 span.redcolor:#ff
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 餐厅前台服务总结
- 酷咖食品科技产业园建设项目可行性研究报告模板-立项拿地
- 10月石家庄房地产市场调研总结报告
- 2025-2030全球环锭细纱机单锭检测系统行业调研及趋势分析报告
- 2025年全球及中国有机天然肥料行业头部企业市场占有率及排名调研报告
- 2025年全球及中国风冷单螺杆式冷水机组行业头部企业市场占有率及排名调研报告
- 2025年全球及中国航空航天设备零部件用超声波清洗机行业头部企业市场占有率及排名调研报告
- 2025年全球及中国网红孵化服务行业头部企业市场占有率及排名调研报告
- 2025-2030全球电池护照(DDP)行业调研及趋势分析报告
- 2025年全球及中国冷加工喷丸机行业头部企业市场占有率及排名调研报告
- 苏教版四年级数学下册第三单元第二课时《常见的数量关系》课件
- 浙江省台州市2021-2022学年高一上学期期末质量评估政治试题 含解析
- 宁夏“8·19”较大爆燃事故调查报告
- 中国高血压防治指南(2024年修订版)解读课件
- 2024年浙江省中考科学试卷
- 初三科目综合模拟卷
- 2024年全国高考新课标卷物理真题(含答案)
- 劳动合同薪酬与绩效约定书
- 足疗店营销策划方案
- 学校安全一岗双责
- 2024年全国版图知识竞赛(小学组)考试题库大全(含答案)
评论
0/150
提交评论