首页 编程开发css选择器

css选择器

发布于: 2012-06-11 11:35:00
字数: 3901
评论: 4
阅读: 5442

css 选择器 简介

要使用 css 对HTML页面中的元素实现一对一,一对多或者多对一的控制,这就需要用到 css 选择器
HTML页面中的元素就是通过 css 选择器 进行控制的。

类别 选择器

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

.demo {
  color:#FF0000;
}

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

  这个区域字体颜色为红色

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

  这个段落字体颜色为红色

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

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

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

  
这个区域字体颜色为红色
  同时,我们可以再定义一个元素:   

这个段落字体颜色为红色

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

标签 选择器

一个完整的HTML页面是有很多不同的标签组成,而标签 选择器 ,则是决定哪些标签采用相应的 css 样式,(在大环境中你可能出于不同的位置,但是不管怎么样,你总是穿着同一套衣服,这件衣服就是由标签 选择器 事先给你限定好的,不管走到哪里都是这身衣服)比如,在style. css 文件中对p标签样式的声明如下:

p {
  font-size:12px;
  background:#900;
  color:090;
}

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

ID 选择器

根据元素ID来选择元素,具有唯一性。前面以”#”号来标记,在样式里面可以这样定义:

#demo{
  color:#FF0000;
}

这里代表id为demoDiv的元素的设置它的字体颜色为红色。我们在页面上定义一个元素把它的ID定义为demo,如:

  这个区域字体颜色为红色

用浏览器浏览,我们可以看到因为区域内的颜色变成了红色, 再定义一个区域:

  这个区域没有定义颜色

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

后代 选择器

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

  黑色   

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

选择器

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

Example Source Code

#links a {color:red;}
#links > a {color:blue;}

我们将会看到第一个链接元素“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标签里面嵌套了一个p标签,这个时候样式可能会出现与预期结果不相同的结果。

群组 选择器

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

p, td, li {
  line-height:20px;
  color:#c00;
}
#main p, #sider span {
  color:#000;
  line-height:26px;
}
.blog_phpat_com, #main p span {
  color:#f60;
}
.text1 h1,#sider h3,.art_title h2 {
  font-weight:100;
}

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

相邻同胞 选择器

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

h1 + p {color:blue}

一个非常专业的 css 站点

Div+ css 教程中,介绍了很多关于 css 网页布局的知识。

css 布局实例中,有很多与 css 布局有关的案例。

我们将会看到第一个段落“Div+ css 教程中,介绍了很多关于 css 网页布局的知识。”文字颜色将会是蓝色。而第二段则不受此 css 样式的影响。+和~的区别:类似上面一个,两者都表示兄弟关系,但是+必须是“大哥+二哥”,~还能是“大哥~三弟”、“二哥~四妹”

属性 选择器

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

abbr[title]{
  color:#FF0000;
}

表示abbr标签是否有title属性,如果有则应用这个样式。也可以用判断html标签的某个属性值的方法来定义 css , 例如:

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

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

总结

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


扫描二维码,在手机上阅读
评论列表:
绝客
2012-08-15 11:19
我想在我的博客实现CSS切换但 一直没成功
双千工程项目
2012-06-12 05:35
希望有机会能够跟博主学习一下css的知识
子恒
2012-06-12 11:31
@双千工程项目:我也是刚学,嘿嘿
双千工程项目
2012-06-12 05:34
对于css我表示真心看不懂啊