CSS选择器

来源:互联网 发布:java json转base64 编辑:程序博客网 时间:2024/05/24 02:17

大部分信息来自于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定义中有更多的选择器类型,但由于各浏览器支持不一,所以不推荐使用,在此不详细叙述。

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 跨省离职后社保怎么办 开车到成都限号怎么办 月经量多怎么办吃什么 报驾校体检视力不达标怎么办 换驾驶证c1一只眼不合格怎么办 考驾照紧张腿抖怎么办 驾照该换了色弱怎么办 怀孕5个月感冒咳嗽怎么办 怀孕4个月喉咙痛怎么办 怀孕5个多月总是咳嗽尿失禁怎么办 怀孕7个月感冒了怎么办 怀孕7个月感冒喉咙痛怎么办 孕38周感冒咳嗽喉咙痛怎么办 嗓子痛咳嗽有痰怎么办 怀孕6个月了咳嗽怎么办 怀孕了咳嗽黄痰怎么办 科二5次没考过怎么办 交警开的罚单丢了怎么办 驾驶员从业资格证被水洗了怎么办 驾照考五次没过怎么办 学车每次考不过怎么办 年检超期3个月怎么办 年检超过3个月怎么办 工商执照年检时候忘记密码怎么办 个体工商营业执照年检过期怎么办 忘了审车时间怎么办 汽车年检超过时间了怎么办 星巴克金星会员到期怎么办 驾考学员证丢了怎么办 违章扣满12分怎么办 违章扣满12分后怎么办 东方时尚驾校科二考不过怎么办 东方时尚科二科三考五次没过怎么办 不想考科目三了怎么办 科目三两次没过怎么办 练科目三很紧张怎么办 驾照学员卡丢了怎么办 驾考时考试的车系统出错怎么办 驾驶证超期6个月怎么办 北京汽车年检只有电子保单怎么办 交电费户号9位数怎么办