实例解析CSS选择符及其用法

开发 前端
你对CSS选择符的概念和用法是否熟悉,这里向大家描述一下,CSS选择符主要包括类型选择符,包含选择符,ID选择符,分组选择法合同配选择符等内容,希望本文介绍对你的学习有所帮助。

本文和大家重点讨论一下CSS选择符的用法,这里将所有的CSS选择符都列举出来了,并对每个CSS选择符做单独的解释和举例,相信本文介绍一定会让你有所收获。

CSS选择符的用法和实例

本文主要讲了CSS选择符(CSSSelectors)用法和相关例子,虽然之前已经有不少对于CSS选择符的文章在网络上出现,不过我还是准备以自己的方式来写一写,这也是一种获得乐趣的途径。所以我小小的总结了一下css1及css2选择符(本文的CSS选择符都为css1及css2)的用法及实例,希望对大家有些许帮助。

现在已经将所有的CSS选择符都列举出来了,将就对每个CSS选择符做单独的解释和举例。对于以下的这些例子,有些只是简单的应用实例,有些还提供了对比例子,使得可以明显的看出该种选择符的使用范围和方法。

类型选择符(TypeSelectors)

  语法:E1

  说明:有的时候我们也将它叫做CSS标签选择符,因为它是直接用html标记来做选择符进行操作。目前所有主流浏览器均支持该选择符,属于CSS1选择符。

  实例: 

  1.   div{color:#F00;}  
  2.   <div>这里是测试内容</div> 
  3.  

包含选择符(DescendantSelectors)

  语法:E1E2

  说明:选择所有被E1包含的E2,这里的E1和E2即可以是html标记,也可以是class或id。目前所有主流浏览器均支持该CSS选择符,属于CSS1选择符。

  实例: 

  1.   divem{color:#F00;}  
  2.   .testem{color:#F00;}  
  3.   <div>这里是<em>测试</em>内容</div> 
  4.   <divclassdivclass="test">这里是<em>测试</em>内容</div> 
  5.  

ID选择符(IDSelectors)

  语法:#sID

  说明:以DOM中作为对象的***标识符的ID作为选择符。目前所有主流浏览器均支持该选择符,属于CSS1选择符。

  实例: 

  1.   #test{color:#F00;}  
  2.   <dividdivid="test">这里是测试内容</div> 
  3.  

类选择符(ClassSelectors)

  语法:.className

  说明:其效果等同于E1[class~=className]。可以为对象的class属性指定多于一个值(className),其方法是用空格将每个className隔开。目前所有主流浏览器均支持该选择符,属于CSS1选择符。

  实例:

  1.   .test{color:#F00;}  
  2.   .test2{font-size:14px;}  
  3.   <dividdivid="test">这里是测试内容</div> 
  4.   <dividdivid="testtest2">这里是测试内容</div> 
  5.  

#p#分组选择符(GroupingSelectors)

  语法:E1,E2,E3

  说明:将同样的定义应用于多个CSS选择符,可以将选择符以逗号分隔的方式并为组。目前所有主流浏览器均支持该选择符,属于CSS1选择符。

  实例: 

  1.   .test,p{color:#F00;}  
  2.   <dividdivid="test">这里是测试内容</div> 
  3.   <p>这里是测试内容</p> 
  4.  

通配选择符(UniversalSelectors)

  语法:*

  说明:选定DOM中的所有对象。目前所有主流浏览器均支持该CSS选择符,属于CSS2选择符。

  实例:

  1.   *{color:#F00;}  
  2.   <div>这里是测试内容</div> 
  3.   <p>这里是测试内容</p> 
  4.  

子选择符(ChildSelectors)

  语法:E1>E2

  说明:选择所有作为E1子对象的E2,不包括孙辈和更深的关系。非IE内核浏览器和IE7及以上浏览器支持,属于CSS2选择符。

  实例:

  1.   .test>strong{color:#F00;}  
  2.   <divclassdivclass="test"> 
  3.    <strong>测试的内容</strong> 
  4.    <p>这是<strong>测试的内容</strong>哦!</p> 
  5.    <strong>测试的内容</strong> 
  6.   </div> 

相邻选择符(AdjacentSelectors)

  语法:E1+E2

  说明:选择紧跟在对象E1之后的所有E2对象(E1与E2需结构级别相同)。非IE内核浏览器和IE7及以上浏览器支持,属于CSS2选择符。

  实例:

  1.   p+p{color:#F00;}  
  2.   <p>测试的内容1</p> 
  3.   <p>测试的内容2</p> 
  4.   <div>测试的内容3</div> 
  5.   <p>测试的内容4</p> 
  6.   <p>测试的内容5</p> 
  7.   <div><p>测试的内容6</p></div> 
  8.  

#p#属性选择符(AttributeSelectors)

  语法:(CSS选择符中的属性选择符具体再分为4种不同的表现方式)

  1.E1[attr]
  2.E1[attr=value]
  3.E1[attr~=value]
  4.E1[attr|=value]

  说明:

  1.选择具有attr属性的E1

  2.选择具有attr属性且属性值等于value的E1

     3.选择具有attr属性且属性值为一用空格分隔的字词列表,其中一个等于value的E1。

  4.选择具有attr属性且属性值为一用连字符分隔的字词列表,由value开始的E1

  非IE内核浏览器和IE7及以上浏览器支持,属于CSS2选择符。

  实例:

  1.   div[title]{color:#f00;}  
  2.   <divtitledivtitle="测试的内容">测试的内容</div> 
  3.  
  4.   div[class=a]{color:#f00;}  
  5.   <divclassdivclass="a">测试的内容</div> 
  6.   <divclassdivclass="ab">测试的内容</div> 
  7.  
  8.   div[class~=a]{color:#f00;}  
  9.   <divclassdivclass="a">测试的内容</div> 
  10.   <divclassdivclass="ab">测试的内容</div> 
  11.  
  12.   div[title|=a]{color:#f00;}  
  13.   <divtitledivtitle="a">测试的内容</div> 
  14.   <divtitledivtitle="abc">测试的内容</div> 
  15.   <divtitledivtitle="a-b-c">测试的内容</div> 
  16.  

 伪类选择符(CSSPseudo-ClassesReference)

  语法:(CSS选择符中的伪类选择符共有10种)

  1.Selector:link{sRules}
  2.Selector:visited{sRules}
  3.Selector:hover{sRules}
  4.Selector:active{sRules}
  5.Selector:focus{sRules}
  6.Selector1Selector2:first-child{sRules}
  7.Selector:first{sRules}
  8.Selector:left{sRules}
  9.Selector:right{sRules}
  10.Selector:lang{sRules}

  说明:

  1.设置a对象在未被访问前的样式表属性。默认值由浏览器决定。对于无href属性(特性)的a对象,此伪类不发生作用。

  2.设置a对象在其链接地址已被访问过时的样式表属性。默认值由浏览器决定。定义网页过期时间或用户清空历史记录将影响此伪类的作用。对于无href属性(特性)的a对象,此伪类不发生作用。

  3.设置对象在其鼠标悬停时的样式表属性。在CSS1中此伪类仅可用于a对象。且对于无href属性(特性)的a对象,此伪类不发生作用。在CSS2中此伪类可以应用于任何对象。

  4.设置对象在被用户激活(在鼠标点击与释放之间发生的事件)时的样式表属性。在CSS1中此伪类仅可用于a对象。且对于无href属性(特性)的a对象,此伪类不发生作用。在CSS2中此伪类可以应用于任何对象。并且:active状态可以和:link以及:visited状态同时发生。

  5.设置对象在成为输入焦点(该对象的onfocus事件发生)时的样式表属性。

  6.设置对象(Selector1)的***个子对象(Selector2)的样式表属性。

  7.设置页面容器***页使用的样式表属性。仅用于@page规则。

  8.设置页面容器位于装订线左边的所有页面使用的样式表属性。仅用于@page规则。

  9.设置页面容器位于装订线右边的所有页面使用的样式表属性。仅用于@page规则。

  10.设置对象使用特殊语言的内容样式表属性。
  
  :link,:visited,:hover,:active属于CSS1,目前所有主流浏览器均支持a对象的该4种伪类选择符,非IE浏览器和IE7及以上浏览器还支持非a对象的:hover,:active;:focus,:lang属于CSS2,非IE核心浏览器及IE8支持。

  实例:

  1.   a:link{color:#f00;}  
  2.   a:visited{color:#666;}  
  3.   a:hover{color:#F60;text-decoration:none;}  
  4.   a:active{color:#000;}  
  5.   <ahrefahref="http://blog.doyoe.com/">css探索之旅</a> 
  6.  
  7.   input:focus,a:focus{background:#f00;
  8. /*点击或按TAB键获得焦点时生效*/}  
  9.   <ahrefahref="http://blog.doyoe.com/">css探索之旅</a> 
  10.   <inputtypeinputtype="text"/> 
  11.  
  12.   divem:first-child{color:#f00;}  
  13.   <div><em>web</em>前端开发<em>权威指南</em></div> 
  14.  

#p#伪对象选择符(CSSPseudo-ElementsReference)

  语法:(CSS选择符中的伪对象选择符共有4种)

  1.Selector:first-letter
  2.Selector:first-line
  3.Selector:before
  4.Selector:after

  说明:

  1.设置对象内的***个字符的样式表属性。此伪对象仅作用于块元素。内联元素要使用该伪对象,必须先设定对象具有块元素的表状。

  2.设置对象内的***行的样式表属性。此伪对象仅作用于块对象。内联对象要使用该伪对象,必须先设定对象具有块元素的表状。

  3.用来和content属性一起使用,设置在对象前(依据对象树的逻辑结构)发生的内容。

  4.用来和content属性一起使用,设置在对象后(依据对象树的逻辑结构)发生的内容。

  这几个伪对象选择符都为属于CSS2选择符,其中:first-letter和:first-line目前所有主流浏览器均支持;:before和:after非IE核心浏览器及IE8支持。

  实例:

  1.   div:first-letter{color:#f00;}  
  2.   <div>我是一只丑小鸭,伊啊伊啊哟</div> 
  3.  
  4.   div:first-line{color:#f00;}  
  5.   <div>我是一只丑小鸭,伊啊伊啊哟</div> 
  6.  
  7.   div:before{content:"web";}  
  8.   <div>前端开发</div> 
  9.  
  10.   div:after{content:"...";}  
  11.   <div>大段的文字</div> 

【编辑推荐】

  1. CSS继承性及其应用
  2. CSS中at(@)指示符用法详解
  3. CSS中link和@import的区别
  4. CSS2.0中page-break-after属性用法
  5. 技术分享 使用不同CSS样式兼容多种浏览器

 

 

 

责任编辑:佚名 来源: css3-html5.com
相关推荐

2010-08-24 09:29:16

CSS选择符

2010-09-06 16:37:58

2010-09-09 16:26:54

CSS选择符

2010-09-03 14:18:45

CSS选择符CSS

2010-08-20 14:58:26

CSSpadding

2010-08-23 15:07:28

IE6CSS

2010-08-18 16:34:53

IE6CSS

2010-09-08 11:06:49

CSSpaddingmargin

2009-09-16 18:16:34

正则表达式

2010-09-07 10:33:04

CSS

2010-09-08 13:01:20

atCSS

2010-09-13 13:21:29

CSS排版

2010-09-10 13:07:51

CSS DIV绝对定位CSS DIV固定定位

2010-09-02 15:12:28

CSS属性值选择器

2010-07-16 08:47:53

Perl if语句

2010-07-20 09:45:04

Perl继承

2010-08-19 11:22:19

marginpadding

2010-08-26 11:13:52

CSSwhite-space

2010-09-03 11:24:49

CSS伪类

2010-08-30 15:26:13

floatCSS
点赞
收藏

51CTO技术栈公众号