如何插入样式表
当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。插入样式表的方法有三种:
外部样式表
当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表。<link> 标签在(文档的)头部:
<head>: _4 E) O, `& `1 C
<link
rel="stylesheet" type="text/css" href="mystyle.css
" />0 I$ q3 ]* @' a
</head>
浏览器会从文件 mystyle.css 中读到样式声明,并根据它来格式文档。
外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。下面是一个样式表文件的例子:
hr {color: sienna;}: O0 A) H9 {3 ?6 {
p {margin-left: 20px;}
; ^& p) y2 f2 i) r7 ~3 lbody {background-image: url("images/back40.gif");}
不要在属性值与单位之间留有空格。假如你使用 “margin-left: 20 px” 而不是 “margin-left: 20px” ,它仅在 IE 6 中有效,但是在 Mozilla/Firefox 或 Netscape 中却无法正常工作。
内部样式表
当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使用 <style> 标签在文档头部定义内部样式表,就像这样:
<head>
- P o w* [0 S5 y/ o v<style type="text/css">
% I1 H! F) ~9 R( `
hr {color: sienna;}9 o9 s7 `* h: v* Z
p {margin-left: 20px;}+ e: e- R/ v) M0 K( d7 t
body {background-image: url("images/back40.gif");}
# p& E: p4 \0 b4 D/ W) z</style>
; y- W$ B- U2 `4 `
</head>
- u2 n7 B- j/ Z
内联样式
由于要将表现和内容混杂在一起,内联样式会损失掉样式表的许多优势。请慎用这种方法,例如当样式仅需要在一个元素上应用一次时。
要使用内联样式,你需要在相关的标签内使用样式(style)属性。Style 属性可以包含任何 CSS 属性。本例展示如何改变段落的颜色和左外边距:
<p style
="color: sienna; margin-left: 20px">3 y9 P8 F. T+ K4 r; e3 G6 i2 c
This is a paragraph: L7 t6 n9 L" O' p( E
</p>3 v+ a3 a9 g A2 t# {# ?
多重样式
如果某些属性在不同的样式表中被同样的选择器定义,那么属性值将从更具体的样式表中被继承过来。
例如,外部样式表拥有针对 h3 选择器的三个属性:
h3 {
% r) u: z$ t1 ]5 r color: red;3 O0 N4 V; Z6 G" B# w% y7 ^$ T- Z
text-align: left
;) H% _/ I+ E) U/ \' u
font-size: 8pt
;+ D/ { p4 E3 E* e
}
而内部样式表拥有针对 h3 选择器的两个属性:
h3 {
1 w& m0 t5 |" o; Z text-align: right
; " Q0 n% m Y! B" N7 `4 m
font-size: 20pt
;
1 F' v$ h0 a) w7 r$ S& W2 N }
假如拥有内部样式表的这个页面同时与外部样式表链接,那么 h3 得到的样式是:
color: red
;
; j& `2 f7 r$ }. ^5 _9 O9 ttext-align: right
; 7 @, I, {' y8 X: K& d+ \! ~ [
font-size: 20pt
;
即颜色属性将被继承于外部样式表,而文字排列(text-alignment)和字体尺寸(font-size)会被内部样式表中的规则取代。