CSS选择器

大部分信息来自于BAIDU,部分信息自己添加。

 

CSS选择器

样式表调用一般情况下包含如下两种:

页面内嵌法:

就是将样式表直接写在页面代码的head区。类似这样:

<style type="text/css">body { background : white ; color : black ; } </style>

外部调用法:

 

将样式表写在一个独立的.css文件中,然后在页面head区用类似以下代码调用。

<link rel="stylesheet"rev="stylesheet" href="css/style.css"type="text/css" media="all" />

 

什么是选择器呢?

每一条css样式定义由两部分组成,形式如下: [code] 选择器{样式}[/code] 在{}之前的部分就是“选择器”。 “选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素

 

类别选择器

类选择器根据类名来选择前面以”.”来标志,如:

.demoDiv{

color:#FF0000;                                                         

}

HTML中,元素可以定义一个class的属性。如:

<divclass="demoDiv">

这个区域字体颜色为红色

</div>

同时,我们可以再定义一个元素:

<pclass="demoDiv">

这个段落字体颜色为红色

</p>

最后,用浏览器浏览,我们可以发现所有classdemoDiv的元素都应用了这个样式。包括了页面中的div元素和p元素。

上例我们给两个元素都定义了class,但如果有很多个元素都会应用这个元素,那得一个个的定义元素,就会造成页面重复的代码太多,这种现象称为多类症

我们可以改成这样来定义。

<divclass="demoDiv">

<div>

这个区域字体颜色为红色

</div>

同时,我们可以再定义一个元素:

<p>

这个段落字体颜色为红色

</p>

</div>

这样,我们就只是定义了一个类,同时把样式应用到了所有的元素当中。

 

DEMO:

 

<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type" content="text/html;charset=utf-8" />

<title>类别选择器20140317</title>

</head>

<styletype="text/css">

.demoDiv{

       color:#FF0000;

}

</style>

 

<body>

 

<divclass="demoDiv">

  这个区域字体颜色为红色

</div>

 

<pclass="demoDiv">

  这个区域字体颜色为红色

</p>

 

<divclass="demoDiv">

这个区域字体颜色为红色

</div>

 

<p>

这个段落字体颜色为红色

</p>

 

</body>

 

</html>

标签选择器

一个完整的HTML页面是有很多不同的标签组成,而标签选择器,则是决定哪些标签

采用相应的CSS样式,(在大环境中你可能出于不同的位置,但是不管怎么样,你总

是穿着同一套衣服,这件衣服就是由标签选择器事先给你限定好的,不管走到哪里

都是这身衣服)比如,在style.css文件中对p标签样式的声明如下:

p{

font-size:12px;

background:#900;

color:090;

}

复制代码则页面中所有p标签的背景都是#900(红色),文字大小均是12px,颜色为#090(绿色),这在后期维护中,如果想改变整个网站中p标签背景的颜色,只需要修改

background属性就可以了,就这么容易!

DEMO:

 

<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type" content="text/html;charset=utf-8" />

<title>标签选择器20140317</title>

</head>

<styletype="text/css">

.demoDiv{

       color:#FF0000;

}

p{

font-size:24px;

background:#900;

color:090;

}

</style>

 

<body>

 

<p> test</p>

</body>

 

</html>

3 ID选择器

根据元素ID来选择元素,具有唯一性。

前面以”#”号来标志,在样式里面可以这样定义:

#demoDiv{

color:#FF0000;

}

这里代表iddemoDiv的元素的设置它的字体颜色为红色。

我们在页面上定义一个元素把它的ID定义为demoDiv,如:

<divid="demoDiv">

这个区域字体颜色为红色

</div>

用浏览器浏览,我们可以看到因为区域内的颜色变成了红色

再定义一个区域

<div>

这个区域没有定义颜色

</div>

用浏览器浏览,与预期的一样,区域没有应用样式,所以区域中的字体颜色还是默认的颜色黑色。

DEMO

 

<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type" content="text/html;charset=utf-8" />

<title>ID选择器20140317</title>

</head>

<styletype="text/css">

#demoDiv{

       color:#FF0000;

}

</style>

 

<body>

 

<divid="demoDiv"> <strong> RED </strong> </div>

</body>

 

</html>

1.4 后代选择器

后代选择器也称为包含选择器,用来选择特定元素或元素组的后代,后代选择器用两个常用选择器,中间加一个空格表示。其中前面的常用选择器选择父元素,后面的常用选择器选择子元素,样式最终会应用于子元素中。

如:

<style>

.father.child{

color:#0000CC;

}

</style>

<pclass="father">

黑色

<labelclass="child">蓝色

<b>也是蓝色</b>

</label>

</p>

这里我们定义了所有class属性为father的元素下面的class属性为child的颜色为蓝色。后代选择器是一种很有用的选择器,使用后代选择器可以更加精确的定位元素。

 

DEMO

 

<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type" content="text/html;charset=utf-8" />

<title>后代选择器20140317</title>

<style>

 

.grandpa {

color:#CC0000;

}

 

.grandpa .father{

color:#00CC00;

}

 

.grandpa .father.child{

color:#0000CC;

}

</style>

</head>

 

<body>

<pclass="grandpa">

RED

</p>

<divclass="grandpa">RED

<pclass="father"> GREEN <labelclass="child">BLUE</label></p> </div>

</p>

</body>

 

</html>

1.5 子选择器

请注意这个选择器与后代选择器的区别,子选择器(child selector)仅是指它的直接后代,或者你可以理解为作用于子元素的第一个后代。而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择,而子选择器是通过“>”进行选择,我们看下面的代码:

Example SourceCode

CSS

#links a{color:red;}

#links > a{color:blue;}

HTML

<pid="links">

<ahref="#">Div+CSS教程</a>>

<span><ahref="#">CSS布局实例</a></span>

<span><ahref="#">CSS2.0教程</a></span>

</p>

我们将会看到第一个链接元素“Div+CSS教程会显示成蓝色,而其它两个元素会显示成红色。当然,或许你的浏览器并不支持这样的CSS选择符。我们在一开始也强调了不太兼容的现状。

子选择器(>)和后代选择器(空格)的区别:都表示祖先-后代的关系,但是>必须是爸爸>儿子,而空格不仅可以是爸爸儿子,还能是爷爷儿太爷爷儿子

伪类选择器

有时候还会需要用文档以外的其他条件来应用元素的样式,比如鼠标悬停等。这时候我们就需要用到伪类了。以下是链接应用的伪类定义。

a:link{

color:#999999;

}

a:visited{

color:#FFFF00;

}

a:hover{

color:#006600;

}

/* IE不支持,用Firefox浏览可以看到效果 */

input:focus{

background:#E0F1F5;

}

Link表示链接在没有被点击时的样式。Visited表示链接已经被访问时的样式。Hover表示当鼠标悬停在链接上面时的样式。

伪类不仅可以应用在链接标签中,也可以应用在一些表单元素中,但表单元素的应用IE不支持,所以一般伪类都只会被应用在链接的样式上。

通用选择器

通用选择器用*来表示。例如:

*{

font-size: 12px;

}

表示所有的元素的字体大小都是12px;同时通用选择器还可以和后代选择器组合。

例如:

p *{

……

}

表示所有p元素后代的所有元素都应用这个样式。但是与后代选择器的搭配容易出现浏览器不能解析的情况,比如像这样子:

<p>

所有的文本都被定义成红色

<b>所有这个段落里面的子标签都会被定义成蓝色</b>

<p>所有这个段落里面的子标签都会被定义成蓝色</p>

<b>所有这个段落里面的子标签都会被定义成蓝色</b>

<em>所有这个段落里面的子标签都会被定义成蓝色</em>

</p>

这个例子里面p标签里面嵌套了一个p标签,这个时候样式可能会出现与预期结果不相同的结果。

群组选择器

当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔。如:

p, td, li {

line-height:20px;

color:#c00;

}

#main p, #siderspan {

color:#000;

line-height:26px;

}

.www_52css_com,#mainp span {

color:#f60;

}

.text1 h1,#siderh3,.art_title h2 {

font-weight:100;

}

使用群组选择器,将会大大的简化CSS代码,将具有多个相同属性的元素,合并群组进行选择,定义同样的CSS属性,这大大的提高了编码效率,同时也减少了CSS文件的体积。

相邻同胞选择器

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

Example SourceCode CSS

h1 + p{color:blue}

HTML

<h1>一个非常专业的CSS站点</h1>

<p>Div+CSS教程中,介绍了很多关于CSS网页布局的知识。</p>

<p>CSS布局实例中,有很多与CSS布局有关的案例。</p>

我们将会看到第一个段落“Div+CSS教程中,介绍了很多关于CSS网页布局的知识。文字颜色将会是蓝色。而第二段则不受此CSS样式的影响。

+~的区别:类似上面一个,两者都表示兄弟关系,但是+必须是大哥+二哥~还能是大哥~三弟二哥~四妹

 

DEMO:

<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type" content="text/html;charset=utf-8" />

<title>ID选择器20140317</title>

<style>

 

h1 + p{color:blue}

 

</style>

</head>

 

<body>

<h1>h1</h1>

<p>CSS布局实例中,有很多与CSS布局有关的案例。</p>

<p>CSS布局实例中,有很多与CSS布局有关的案例。</p>

<p>Div+CSS教程中,介绍了很多关于CSS网页布局的知识。</p>

<p>CSS布局实例中,有很多与CSS布局有关的案例。</p>

 

</body>

 

</html>

10 属性选择器

您可以用判断html标签的某个属性是否存在的方法来定义css

例如:

abbr[title]{

color:#FF0000;                                                                      

}

表示abbr标签是否有title属性,如果有则应用这个样式。

也可以用判断html标签的某个属性值的方法来定义css

例如:

p[title='app']{ color:#FF0000;

}

这里所有p标签中,title属性为app的都会应用这个样式。

总结

css3定义中有更多的选择器类型,但由于各浏览器支持不一,所以不推荐使用,在此不详细叙述。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值