css选择器优先级深入理解

转载自:http://www.jb51.net/css/67029.html

一、基础选择器

css基础选择器有标签选择器、类选择器、id选择器、通用选择器

1.标签选择器

每个html页面都由很多个标签组成,通过标签选择器可以对某类标签应用相应的样式,如对p标签应用下面的样式,则页面中所有的p标签都会生效

p{ font-size:12px; color:red; background:blue; } 

2.类选择器

类选择器是css非常常用的选择器,在html中可以为某个标签增加class属性,如

<div class="error"> </div>

则可以为对应的class设置样式

error{ width:200px; padding:5px; color:red;} 

类选择器可以复用,如对页面中的p标签也可以应用

<p class="error"> </p> 

另外,一个标签可以有多个类选择器,不同的值用空格隔开,这样多个样式便可以应用的一个标签上。

3.id选择器

id选择器和类选择器一样,用的也很频繁,但是id在每个html页面的值必须是唯一的,所以它不可以复用,如:

<div id="content"> </div> 

这里补充说明下id与class的命名规范,命名时尽可能的保持名称与表现形式无关,如 某段提示文字显示为红色,可以命名为red,但是若日后改成蓝色,则red名与之不对应,更好的选择如error或tips。所以应该根据它是什么来命名 而不是 根据 它的外观如何来命名。

4.通用选择器

不同于上面的三种选择器,通用选择器要强大的多,它可以对页面中的所有html标签应用样式,当然也正是因为如此强大,反而限制了它的灵活性,在实际应用中用的较少。一般简单的css reset会用到,如:

*{ margin:0; padding:0;} 

二、组合选择器

1.群主选择器

在使用选择器时,有的元素样式是一样的,每次都为不同的选择器单独定义样式的话太繁琐,这时我们便可以使用群主选择器集中定义样式。不同标签或类以逗号隔开。如:

div, h2, .error{ font-size:14px; color:red;} 

这样我们便同时给div, h2, .error一起定义了样式。

2.子选择器

当我们想让父元素下的某个子元素表现为特定的样式时,我们可以用子选择器,如

div>a{ color:blue; text-decoration:none;} 

此时,div下的子元素a都将变成蓝色字体,无下划线。

3.后代选择器

在上面的例子中,利用子选择器,只可以设置div下的子元素a,但是若想改变div下的所有a标签的样式,就需要用到后代选择器。代码如下:

div a{ color:blue; text-decoration:none;}

4.同胞选择器

除了上面的子选择器与后代选择器,我们可能还希望找到兄弟两个当中的一个,如一个标题h1元素后面紧跟了两个段落p元素,我们想定位第一个段落p元素,对它应用样式。我们就可以使用相邻同胞选择器。看下面的代码:

h1 + p{font-size:14px; background:#ccc; } 

三、属性选择器说明:以下提到的E表示元素,attr表示属性,val表示属性的值

1.E[attr]选择器

匹配所有具有attr属性的E元素,不考虑它的值。如以下代码可以匹配所有含有title属性的p元素。

p[title]{font-size:12px; color:#666;} 

2.E[attr=val]

匹配所有attr属性值为val的E元素。如匹配所有class值为test的p元素

p[class="test"]{color:red;} 

3.E[attr~=val]

匹配具有attr属性且属性值为用空格分隔的字符列表,其中一个值等于val的E元素。如:

p[class~="name"]{font-size:12px; color:red;}
<div class="test name">111111</div><div class="name">111111</div>

则第一个div会应用上面的样式。

4.E[attr|=val]

匹配具有attr属性且属性值为用连接符分隔的字符串,并以val开头的E元素。

p[class|="test"]{font-size:12px; color:red;} 
<div class="test">111111</div>
<div class="test-123">111111</div> 

则第二个div会应用上面的样式。

最后不得不提的是IE6不支持子选择器、同胞选择器和属性选择器,因此使用时需注意。

css优先级

优先级算是css中的一个非常重要的知识点,也是笔试面试中经常会考到的知识点。

一、什么是css优先级

css优先级,即是指CSS样式在浏览器中被解析的先后顺序。

二、css优先级规则

比较简单易记的一种方法就是给不同选择器分配不同的值:

1.id选择器默认优先级最高,其权值为100

2.class选择器、属性选择器和伪类选择器的权值为10

3.标签选择器的优先级较低,其权值为1

所以在比较样式的优先级时,只需统计选择符中的id、class、标签名个数,然后把对应的权值相加即可。根据结果便可得出优先级高低。

1.结果较大的优先级较高

2.结果相同,则后定义的样式优先级较高

3.如果样式值中含有!important,则该值优先级最高

举例:

h2{color:blue;}//其权值为1
#content{color:#666;}//其权值为100p
.test{color:#ccc;}//其权值为1+10=11
#main div .test{color:red;}//其权值为100+1+10=111div
#main .left #nav{color:#000}//其权值为1+100+10+100=211 
时间: 2024-10-01 07:08:42

css选择器优先级深入理解的相关文章

CSS选择器优先级【转】

样式的优先级 多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External style sheet <(内部样式)Internal style sheet <(内联样式)Inline style 有个例外的情况,就是如果外部样式放在内部样式的后面,则外部样式将覆盖内部样式. 示例如下: <head>     <style type="text/css&

css选择器 优先级的问题

最近写代码时发现,有时候写出的样式不会被引用.看了一些其他人写的网站源码后,我发现了这样写可以解决问题,如下: 比如说<div class="abc">  <div class="edf">     <div class="fgg">    </div>  </div></div>确定class="fgg"时,写成:.abc .efg .fgg{/* 代码

CSS选择器优先级(转)

原文:http://www.cnblogs.com/wangfupeng1988/p/4285251.html 另外,w3c有文章介绍了CSS选择器的特定性,见https://www.w3.org/TR/css3-selectors/#specificity 1. 引言 上一节<css知多少(5)——选择器>最后提到,选择器类型过多将导致一些问题,是什么问题呢?咱们直接举例子说明. 上图中,css中的两个选择器都是针对<span>的,而且两个设置的颜色不一样,这里的<span

CSS总结(四)—— CSS选择器优先级

css选择器优先级 优先顺序: 1.!important (IE6不支持此属性) 2.html中元素标签添加的style=“”(css难以管理,不推荐) 3.一个或多个id选择器 例:#top{margin:0;} 4.一个或多个类选择器(包括属性.伪类选择器) 例:.outer{}   [data-job="frontend"]{}    a:active{} 5.标签选择器 例:div{margin:3px;} 6.通配选择器 例:*{margin:10px;} ★ 选择器规则:

一道关于CSS选择器优先级的题

<span style="font-size:14px;"><html> <head> <style type="text/css"> #redP p { /* 权值 = 100+1=101 */ color:#F00; /* 红色 */ } #redP .red em { /* 权值 = 100+10+1=111 */ color:#00F; /* 蓝色 */ } #redP p span em { /* 权值 =

深入理解CSS选择器优先级的计算

选择器的优先级关系到元素应用哪个样式.在CSS2.1的规范(http://www.w3.org/TR/2009/CR-CSS2-20090908/cascade.html#specificity)中是这样描述的: 如果声明来自于“style”属性,而不是带有选择器的规则,则记为 1,否则记为 0 (= a)(HTML元素的style属性也是样式规则,因为这些样式规则没有选择器,因此记为a=1,b=0,c=0,d=0) 计算选择器中 ID 属性的个数 (= b) 计算选择器中其他属性(类.属性选择

CSS选择器优先级总结

CSS三大特性-- 继承. 优先级和层叠. 继承:即子类元素继承父类的样式; 优先级:是指不同类别样式的权重比较; 层叠:是说当数量相同时,通过层叠(后者覆盖前者)的样式. css选择符分类 首先来看一下css选择符(css选择器)有哪些? 1.标签选择器(如:body,div,p,ul,li) 2.类选择器(如:class="head",class="head_logo") 3.ID选择器(如:id="name",id="name_t

CSS选择器优先级比较

CSS选择器的优先级,一般根据就近原则,更准确一点,根据选择器的权值大小比较,权值越高,则优先级越高.如果加上!important则优先级最高. 权值大小: !important 1000 id 100 class 10 属性 10 伪类 10 伪元素 10 标签 1 通配符* 0

导航栏布局时遇到的问题以及解决办法 css选择器优先级

得到的导航栏效果 添加#menu ul li{width:30px;} 效果如图 将会使列表项和分隔区域的宽度同时改变因为id选择器的优先级高于类选择器,此时应该为列表项添加内联样式如图 才能得到如下效果 或者可以使用第二种方法 #menu ul li{ float:left; margin-left:10px;text-align:center;padding-left:10px;实现列表项文字的居中 line-height:28px; height:28px; width:40px; bor