详解CSS选择器、优先级与匹配原理

选择器种类

      严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=""的方式,应该是CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。而一般人们将上面这几种方式结合在一起,所以就有了5种或6种选择器了。


基本的选择器类型

语法如下:

  • 通用选择器,如*{}。
  • 标签名选择器,如:p{},即直接使用HTML标签作为选择器。
  • 类选择器,如.citys{}。
  • ID选择器,如#citys{}。

注意,ID选择器跟类选择器有很大的不同:一个页面内不能出现相同的ID;再就是ID也是后台开发人员会经常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合十分娴熟之后,这些都不会成为限制。


扩展选择器

  • 后代选择器,如.citys span img{},后代选贼器实际上是使用多个选择器加上中间的空格来找到具体的要控制标签。
  • 群组选择器,如div,span,img{},群组选择器实际上是对CSS的一种简化写法,只不过把有相同定义的不同选择器放在一起,省了很多代码。


选择器的优先级别

了解了各种选择器后,还有一个重要的知识点就是CSS选择器的优先级。举个简单的例子:

<div class="citys"> <span class="beijing"> 北京 </span> <span> 上海	  </span> 
</div> 
如果已经把.citys下span内的字体设置成红色:

.citys span {color:red;} 

这时,如果要改变.beijing的颜色为蓝色,用下面的命令是不能实现的:

.beijing {color:blue;} 

出现这种情况就是因为后一个命令的优先级不够,两条相互冲突的样式设置,浏览器只会执行优先级较高的那个。


那么选择器的优先级是怎么规定的呢?

       一般而言,选择器越特殊,它的优先级越高。也就是选择器指向的越准确,它的优先级就越高。通常我们用1表示标签名选择器的优先级,用10表示类选择器的优先级,用100标示ID选择器的优先级。比如上例当中 .citys span {color:red;}的选择器优先级是 10 + 1 也就是11;而 .polaris 的优先级是10;浏览器自然会显示红色的字。理解了这个道理之后下面的优先级计算自是易如反掌:

div.test1 .span var 优先级 1+10 +10 +1  
span#xxx .songs li 优先级1+100 + 10 + 1  
#xxx li 优先级 100 +1 

对于什么情况下使用什么选择器,用不同选择器的原则是:

第一:准确的选到要控制的标签;

第二:使用最合理优先级的选择器;

第三:HTML和CSS代码尽量简洁美观。

通常:

1、最常用的选择器是类选择器。
2、li、td、dd等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器 .xx li td dd {} 的方式选择。
3、极少的情况下会用ID选择器,当然很多前端开发人员喜欢header,footer,banner,conntent设置成ID选择器的,因为相同的样式在一个页面里不可能有第二次。

在这里不得不提使用在标签内引入CSS的方式来写CSS,即:

<div style="color:red">北京</div> 
这时候的优先级是最高的。我们给它的优先级是1000,这种写法不推荐使用,特别是对新手来说。这也完全违背了内容和显示分离的思想。DIV+CSS的优点也不能再有任何体现。

后代选择器的定位原则


在这里介绍一下对于后代选择器,浏览器是如何查找元素的呢?

        浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如DIV#divBox p span.red{color:red;},浏览器的查找顺序如下:先查找html中所有class='red'的span元素,找到后,再查找其父辈元素中是否有p元素,再判断p的父元素中是否有id为divBox的div元素,如果都存在则匹配上。

浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css:

CSS:
#divBox p span.red{color:red;}  HTML:
<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> 
如果按从左到右查找,哪会先查找到很多不相关的p和span元素。而如果按从左到右的方式进行查找,则首先就查找到<span class='red'>的元素。firefox称这种查找方式为key selector(关键字查询),所谓的关键字就是样式规则中最后(最右边)的规则,上面的key就是span.red。

简洁、高效的CSS


所谓高效的CSS就是让浏览器在查找style匹配的元素的时候尽量进行少的查找,下面列出一些我们常见的写CSS犯一些低效错误:

◆不要在ID选择器前使用标签名
一般写法:DIV#divBox
更好写法:#divBox
解释: 因为ID选择器是唯一的,加上div反而增加不必要的匹配。

◆不要再class选择器前使用标签名
一般写法:span.red
更好写法:.red
解释:同第一条,但如果你定义了多个.red,而且在不同的元素下是样式不一样,则不能去掉,比如你css文件中定义如下:

p.red{color:red;}  
span.red{color:#ff00ff} 
如果是这样定义的就不要去掉,去掉后就会混淆,不过建议最好不要这样写

◆尽量少使用层级关系
一般写法:#divBox p .red{color:red;}
更好写法:.red{..}

◆使用class代替层级关系
一般写法:#divBox ul li a{display:block;}
更好写法:.block{display:block;}







本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373769.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于299$的企业开发者账号的申请流程

299$的企业开发者账号 Apple Developer Enterprise Program•一年1988人民币 - 企业 (Apple Developer Enterprise Program)- 公司应在邓白氏注册并拥有有效的 DUNS 号码。&#xff0d;此计划使开发者能够开发针对 Apple 设备的应用程式&#xff0c;并对其员工进行发布&#xf…

keras 多层lstm_tensorflow-如何在keras中堆叠多个lstm?

DanielAdiwardana的答案的详细说明。我们需要为除最后一层之外的所有LSTM层添加return_sequences True。将此标志设置为True可让Keras知道LSTM输出应包含所有历史生成的输出以及时间戳(3D)。 因此&#xff0c;下一个LSTM层可以进一步处理数据。如果此标志为假&#xff0c;则LS…

Java堆空间– JRockit和IBM VM

本文将为您提供JRockit Java堆空间与HotSpot VM的概述。 它还将为您提供有关JRockit和HotSpot的Oracle未来计划的一些背景知识。 Oracle JRockit VM Java堆&#xff1a;2个不同的内存空间 -Java堆&#xff08;YoungGen和OldGen&#xff09; -本机内存空间&#xff08;类池&am…

如何搭建lamp(CentOS7+Apache+MySQL+PHP)环境 [转]

在网上搜资料,自己在本地虚拟机上尝试搭建,弄了整整一天一夜,终于弄好了.网上的资料,虽然很多,但大多都是重复的,拿去试了之后,又很多都不能得到正确的结果.最终找到了适合我的linux环境的搭建方式;在这里贴出来:Install Apache, PHP And MySQL On CentOS 7 (LAMP)度娘真不给力…

为什么要用!DOCTYPE声明

实例&#xff1a; 我们经常会看到类似这样的代码&#xff1a; <!DOCTYPE html> <html> <head> <title>文档的标题</title> </head> <body> 文档的内容...... </body> </html>注解&#xff1a;可以看到最上面有一行关于“…

java 线程的开始、暂停、继续

Android项目中的一个需求&#xff1a;通过线程读取文件内容&#xff0c;并且可以控制线程的开始、暂停、继续&#xff0c;来控制读文件。在此记录下。 直接在主线程中&#xff0c;通过wait、notify、notifyAll去控制读文件的线程&#xff08;子线程&#xff09;&#xff0c;报错…

为什么要在Java中使用Unchecked异常而不是Checked异常

关于检查与未检查的异常的争论可以追溯到过去。 有人说这是Java包含的最佳功能之一。 其他人则说这是他们最大的错误之一[ 1 ]。 辩论似乎结束了。 在这篇文章中&#xff0c;我将尝试包含指向该主题的文章和书籍的链接。 我不是专家&#xff0c;但是我会尽力向您解释为什么我得…

batchplot插件用法_Batchplot批量打印怎么用?Batchplot批量打印教程

很多从事CAD设计工作的用户都碰到过这种情况&#xff1a;在一个单DWG格式的图纸文件中包含有大量图纸&#xff0c;如果一张一张选取打印不但费时费力&#xff0c;而且容易遗漏某张图纸&#xff0c;这时候就需要用到Batchplot插件&#xff0c;这是专门针对单DWG多图纸的批量打印…

选择排序和冒泡排序以及折半查找

1.选择排序 2.冒泡排序 3.折半查找 方式一&#xff1a;开发使用的方法 方式二&#xff1a;普通的折半 转载于:https://www.cnblogs.com/juncaoit/p/5935068.html

JSP中Request属性范围

JSP属性范围&#xff0c;通过以下几个测试代码来学习request属性的范围 测试一(JSP动态指令方式传参)&#xff1a; 测试内容&#xff1a; <jsp:param .../>添加参数,通过<jsp:forward page"...">来实现服务器端跳转,以此来测试request属性的范围&#…

Spring MVC – Flash属性

最新的Spring Framework版本&#xff08;3.1&#xff09;带来了有趣的功能&#xff0c;称为Flash属性。 这是对我很久以前在我的一篇文章中提到的问题的补救措施&#xff1a; Spring MVC –会话属性处理。 这个问题可以用几句话来形容&#xff1a;如果我们想通过两个控制器之间…

000 快速排序算法

一&#xff1a;概述 快速排序是东尼.霍尔所发展的一种快速排序算法。 对于n个项目的排序&#xff0c;平均O&#xff08;n*logn&#xff09;次比较&#xff0c;在比较糟糕的情况下是O&#xff08;n2&#xff09;次比较。 采用分治策略把一个串行分为两个子串行。 二&#xff1a;…

nginx post请求超时_nginx记录分析网站响应慢的请求(ngx_http_log_request_speed)

nginx模块ngx_http_log_request_speed可以用来找出网站哪些请求很慢&#xff0c;针对站点很多&#xff0c;文件以及请求很多想找出哪些请求比较慢的话&#xff0c;这个插件非常有效.作者的初衷是写给自己用的&#xff0c;用来找出站点中处理时间较长的请求, 这些请求是造成服务…

如何用angularjs制作一个完整的表格之一__创建简单表格

初步接手人生的第一个项目&#xff0c;需要用angularjs制作表格和实现各种功能&#xff0c;因此遇到了各种问题和以前不熟悉的知识点&#xff0c;在此记录下来&#xff0c;以供大家学习交流&#xff0c;解决方式可能并不完善或符合规范&#xff0c;如果大家有更好的方式欢迎指出…

Java的String类是上帝的对象吗?

10月&#xff0c;我写了一个博客&#xff0c;题为“上帝对象中的顶级特朗普”&#xff0c;其中谈到了用167种不同的方法发现的对象的发现&#xff0c;这些方法将该对象与应用程序的所有其他部分链接在一起&#xff0c;并且正如您所期望的那样&#xff0c;上帝或怪物物的一般标准…

十步完全理解SQL

很多程序员视 SQL 为洪水猛兽。SQL 是一种为数不多的声明性语言&#xff0c;它的运行方式完全不同于我们所熟知的命令行语言、面向对象的程序语言、甚至是函数语言&#xff08;尽管有些人认为 SQL 语言也是一种函数式语言&#xff09;。 我们每天都在写 SQL 并且应用在开源软件…

curl命令java_上curl java 模拟http请求

最近&#xff0c;我的项目要求java模拟http请求&#xff0c;获得dns解决 tcp处理过的信息特定的连接。java api提供urlConnection apache提供的httpClient都不能胜任该需求&#xff0c;二次开发太费时间。于是google之。最后 得出两种解决的方法&#xff1a;一是使用HTTP4J。该…

androidstudio 优化gradle编译效率

androidstuido 使用gradle自己主动构建和编译。有时做少量改动编译须要等待时间过长&#xff0c;近期Erik Hellman编写的Boosting the performance for Gradle in your Android projects&#xff08; 译文 參考1&#xff09;提到了此问题的优化方法。1.gradle的升级到2.4 。 2.…

Common Knowledge_快速幂

问题 I: Common Knowledge 时间限制: 1 Sec 内存限制: 64 MB提交: 9 解决: 8[提交][状态][讨论版]题目描述 Alice and Bob play some game in which they score points. Each of the two has an n-digit scoreboard which depicts numbers in base 10 (with leading zeroes).…

播放2.0:Akka,Rest,Json和依赖项

在过去的几个月中&#xff0c;我越来越多地涉足scala。 Scala与“ Play框架”一起为您提供了一个非常有效且快速的开发环境&#xff08;即&#xff0c;您掌握了Scala语言的特质之后&#xff09;。 Play框架背后的家伙一直在努力开发新版本的Play 2.0。 在Play 2.0中&#xff0c…