|
一些新手朋友对选择器一知半解,不知道在什么情况下运用什么样的选择器,这是一个比较头疼的问题,针对新手朋友,对CSS选择器作一些简单的说明,希望能对大家的学习工作有一定的帮助,更多的CSS知识请参考Webjx.com的其他文章。 准确而简洁的运用CSS选择器会达到非常好的效果。我们不必通篇给每一个元素定义类(class)或ID,通过合适的组织,可以用最简单的方法实现同样的效果。在实际工作中,最常用的选择器有以下五类:
一、标签选择器:
顾名思议,标签选择器是直接将HTML标签作为选择器,可以是p、h1、dl、strong等HTML标签。如:
p { font:12px;}
em { color:blue;}
dl { float:left; margin-top:10px;}
二、id选择器:
我们通常给页面元素定义id。例如定义一个层 <div id="menubar"></div> 然后在样式表里这样定义:
#menubar {
margin:0 auto;
background:#ccc;
color:#c00;
}
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
id选择器也同样支持后代选择器,例如: #menubar p { text-align:center; line-height:20px;; } 这个方法主要用来定义层和那些比较复杂,有多个“唯一后代”的元素。//本文转自www.45it.com电脑软硬件应用网
三、类(class)选择器:
在CSS里用一个点开头表示类别选择器定义,例如:
.da1 {
color:#f60;
font-size:14px ;
}
在页面中,用class="类别名"的方法调用: <span class="da1">14px大小的字体</span> 这个方法比较简单灵活,可以随时根据页面需要新建和删除。但需要避免多class综合症。
四、群组选择器:
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔。如:
p, td, li {
line-height:20px;
color:#c00;
}
#main p, #sider span {
color:#000;
line-height:26px;
}
.www_52css_com,#main p span {
color:#f60;
}
.text1 h1,#sider h3,.art_title h2 {
font-weight:100;
}
使用组群选择器,将会大大的减化CSS代码,将具有多个相同属性的元素,合并群组进行选择,定义同样的CSS属性,这大大的提高了编码效率与CSS文件体积。
五、后代选择器:
后代选择器也叫派生选择器。可以使用后代选择器给一个元素里的子元素定义样式,例如这样:
li strong {
font-style:italic;
font-weight:800;
color:#f00;
}
#main p {
color:#000;
line-height:26px;
}
#sider .con span {
color:#000;
line-height:26px;
}
.www_52css_com p span {
color:#f60;
}
#sider ul li.subnav1 {
margin-top:5px;
} 第一段,就是给li下面的子元素strong定义一个斜体加粗而且套红的样式。其他以此类推。
后代选择器的使用是非常有益的,如果父元素内包括的HTML元素具有唯一性,则不必给内部元素再指定class或id,直接应用此选择器即可,例如下面的h3与ul就不必指定class或id。
<div id="sider">
<h3></h3>
<ul>
<li>...</li>
<li>...</li>
<li>...</li>
</ul>
</div>
在这里CSS就可以及样写:
#sider h3 {...}
#sider ul {...}
#sider ul li {...}
结合使用上面的四种CSS选择器,基本满足了CSS布局的需要,主要在于灵活的使用,特别是后代选择器的使用能大大的简化HTML文档,使HTML做到结构化明确,最小的代码实现同样的效果。
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active。
例如:
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
a:active {font-weight : bold ;text-decoration : none ;color : #F90 ;}
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预期的不一致。记住它们的顺序是“LVHA”。
selector有三种方式:HTML selector , CLASS selector , ID selector
还有几个扩充的选择器:关联选择器,组合选择器,伪元素选择器
HTML selector:比如上节课所学的P标签就是一个HTML selector。
CLASS selector:比如一个网页上的P标签要分成不同的颜色显示,就要用到CLASS selector。
DE><head>
<style>
<!--
p.stop{color:red}
p.warning{color:yellow}
p.normal{color:green}
-->
</style>
</head>
<body>
<p class="stop">第一部分</p>
<p class="warning">第二部分</p>
<p class="normal">第三部分</p>DE>
DE></body>
DE>
|
还有一种定义方式:
DE><style>
.blueone{color:blue}
</style>
比如:
<h1 class="blueone">蓝色的题目</h1>
<p class="blueone">蓝色的段落</p>DE>
|
ID selector:是用来定义某一个特定的HTML元素。
DE><style>
<!--
#yellowone{color:yellow}
-->
</style>
<body>
<span ID="yellowone">text here</span>
</body>DE>
|
在CSS中应该少用ID selector,但在javascrip里面会得已广范使用。因为可以根据这个ID值来操纵和定位这个特定的HTML标签。
ID selector和使用内联样式表设 置HTML元素的style属性,都可以设置单个HTML元素的样式。怎么选择它们呢?如果网页只在某种媒介上输出时,才需要对某个单一元素进行样式设 置,应该使用ID selector代替直接设置HTML元素的style属性的内联样式表,因为对style属性设置不能绑定到某种特定的输出媒介上。有时在网页中使用了 嵌入样式和输入样式表后直接使用内联样式表后,如果还要对某个元素的显示单独的样式的话,就要用到内联样式表了。
关联选择器:指用一个空格隔开的两个或更多的单一选择器组成的字符串。
DE><style>
<!--
P A{color:blue}
-->
</style>DE>
|
这段代码的意思是:作用于P标签对下面的A标签对。也就是说在P标签对当中,如果有A标签对,这个A标签对就用样式表定义的颜色。
关联选择器比单一选择器的优先权要高。
组合选择器:可以对多个标签对采用相同的样式。
DE><style>
<!--
h1,h2,h3{color:blue}
-->
</style>DE>
样式规则的选择器
DE>html选择器
id选择器
class选择器
关联选择器
组合选择器
伪元素选择器
DE> |
|