|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14387
- 金币
- 2479
- 威望
- 1647
- 贡献
- 1427
|
在开始正式内容制作之前,我们必须先了解一下web标准有关代码的规范。了解这些规范可以帮助你少走弯路,尽快通过代码校验。
% @+ ?+ @( P X9 V1.所有的标记都必须要有一个相应的结束标记
( Z/ }$ [3 c. n0 g以前在HTML中,你可以打开许多标签,例如<p>和<li>而不一定写对应的</p>和< /li>来关闭它们。但在XHTML中这是不合法的。XHTML要求有严谨的结构,所有标签必须关闭。如果是单独不成对的标签,在标签最后加一个 "/"来关闭它。例如:& \) ]& O4 ]* ?3 k. }. L
<br /><img height="80" alt="网页设计师" src="../images/logo_w3cn_200x80.gif" width="200" /> , ]) j& `* h( e( @& b- J, N
2.所有标签的元素和属性的名字都必须使用小写* |) ~8 Y5 ^* T% M) a/ Y8 r
与HTML不一样,XHTML对大小写是敏感的,<title>和<TITLE>是不同的标签。XHTML要求所有的标签和属性的名字都必须使用小写。例如:<BODY>必须写成<body> 。大小写夹杂也是不被认可的,通常dreamweaver自动生成的属性名字"onMouseOver"也必须修改成"onmouseover"。
- R0 c' L8 Q# h/ `3.所有的XML标记都必须合理嵌套
8 j( {9 P" k$ k- x# v同样因为XHTML要求有严谨的结构,因此所有的嵌套都必须按顺序,以前我们这样写的代码:
4 n, T- _' P- {. j$ W% t: M& C<p><b></p>/b> ! n( B% A2 P1 b- _: }: S
必须修改为:* J, t2 A" Z& T; a& P! N3 c1 F
<p><b></b>/p>
+ ]/ o. N4 E& z4 H就是说,一层一层的嵌套必须是严格对称。
; c6 A. m9 ^% L X2 H$ q4.所有的属性必须用引号""括起来( ~1 k8 D* U, j, ~5 s8 j9 Y+ ?
在HTML中,你可以不需要给属性值加引号,但是在XHTML中,它们必须被加引号。例如:
" O2 X* c& F. J( B) [6 `. g<height=80>
' d n1 _. c+ x' r必须修改为:% K, J# Y$ ?& |* P1 m- w9 |
<height="80">
6 X/ `) ]7 K7 t8 [: g4 d# w特殊情况,你需要在属性值里使用双引号,你可以用",单引号可以使用’,例如:
% y _* Y' W6 r. M<alt="say’hello’"> 7 L" q# ?$ x! r$ V$ x
5.把所有<和&特殊符号用编码表示
. a: P0 d+ h$ z. l- v任何小于号(<),不是标签的一部分,都必须被编码为& l t ;
2 O6 b7 m v2 ?6 p任何大于号(>),不是标签的一部分,都必须被编码为& g t ;
2 B! p Z; U+ r: \, _6 f1 o任何与号(&),不是实体的一部分的,都必须被编码为& a m p; , f' E- }4 d. O6 m J, @2 |
注:以上字符之间无空格。
: [" w& @1 F! @5 y& y9 b E6.给所有属性赋一个值
- {: `6 p5 E0 _! _+ Q; D2 [XHTML规定所有属性都必须有一个值,没有值的就重复本身。例如:& ?3 f, n/ K! e- G
<td nowrap> <input type="checkbox" name="shirt" value="medium" checked> % r; D' } c- T/ t1 G
必须修改为:9 D$ Y: N5 d: ~- U1 g
<td nowrap="nowrap"> <input type="checkbox" name="shirt" value="medium" checked="checked"> $ M; p4 t8 h7 j, V' w# [
7.不要在注释内容中使“--”3 Y7 f* f/ k: x
“--”只能发生在XHTML注释的开头和结束,也就是说,在内容中它们不再有效。例如下面的代码是无效的:& ]! v8 M) q' p* I
<!--这里是注释-----------这里是注释--> 2 ?$ ?/ {2 d3 z; p1 J" S
用等号或者空格替换内部的虚线。
0 H1 w* _- s b% O2 f W<!--这里是注释============这里是注释--> 1 {' G1 B6 D5 G0 h( P
以上这些规范有的看上去比较奇怪,但这一切都是为了使我们的代码有一个统一、唯一的标准,便于以后的数据再利用。 |
|