  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14247
- 金币
- 2414
- 威望
- 1647
- 贡献
- 1362
|
在开始正式内容制作之前,我们必须先了解一下web标准有关代码的规范。了解这些规范可以帮助你少走弯路,尽快通过代码校验。 % i/ R$ V5 g) X5 l, }
1.所有的标记都必须要有一个相应的结束标记6 i( a& B5 G' E7 M
以前在HTML中,你可以打开许多标签,例如<p>和<li>而不一定写对应的</p>和< /li>来关闭它们。但在XHTML中这是不合法的。XHTML要求有严谨的结构,所有标签必须关闭。如果是单独不成对的标签,在标签最后加一个 "/"来关闭它。例如:) i3 ~# ?' {! j m& ?+ x6 x0 {
<br /><img height="80" alt="网页设计师" src="../images/logo_w3cn_200x80.gif" width="200" />
# R+ V+ H& Q! x8 X2.所有标签的元素和属性的名字都必须使用小写6 [ D( u- Y- L0 T2 g
与HTML不一样,XHTML对大小写是敏感的,<title>和<TITLE>是不同的标签。XHTML要求所有的标签和属性的名字都必须使用小写。例如:<BODY>必须写成<body> 。大小写夹杂也是不被认可的,通常dreamweaver自动生成的属性名字"onMouseOver"也必须修改成"onmouseover"。 i. H. O- Y- w" F
3.所有的XML标记都必须合理嵌套
: n2 X; O, K2 f+ i同样因为XHTML要求有严谨的结构,因此所有的嵌套都必须按顺序,以前我们这样写的代码:9 t6 I7 r+ W* A( [& i
<p><b></p>/b> 7 `% u A4 L0 P2 U9 @
必须修改为:1 `: G. E8 ~- j6 v6 Y
<p><b></b>/p> ) ?$ A; P" w( X. z9 `
就是说,一层一层的嵌套必须是严格对称。) M z$ |: n1 ?& v0 e
4.所有的属性必须用引号""括起来6 |3 Q5 }9 ]$ h4 d4 r/ t
在HTML中,你可以不需要给属性值加引号,但是在XHTML中,它们必须被加引号。例如:
9 R Y1 O# J' i: k" m<height=80> " d9 C$ C8 ?2 F4 R
必须修改为:
/ `% ^7 y: r7 |# S1 ^: T<height="80">
8 d# {$ X: T! p9 q& X特殊情况,你需要在属性值里使用双引号,你可以用",单引号可以使用’,例如:
8 Q7 a2 x0 a& U0 B; m/ n; i$ L2 U<alt="say’hello’"> / f4 A, J6 l% U* t2 ?
5.把所有<和&特殊符号用编码表示+ R. [9 R% T: l% w; {" v) U
任何小于号(<),不是标签的一部分,都必须被编码为& l t ; ' Z/ Q- q0 k9 a% K, D$ T
任何大于号(>),不是标签的一部分,都必须被编码为& g t ;
9 Q% d6 A, ]- K4 }6 h任何与号(&),不是实体的一部分的,都必须被编码为& a m p;
8 n6 W2 @' h/ f5 F. T注:以上字符之间无空格。# N/ \2 @0 `. z+ |
6.给所有属性赋一个值
& Z5 m$ ?# v: {! VXHTML规定所有属性都必须有一个值,没有值的就重复本身。例如:3 k; I2 k( H" o
<td nowrap> <input type="checkbox" name="shirt" value="medium" checked>
; G$ \# L3 R& g" V1 |8 E必须修改为:
8 j8 c3 @1 Z. [8 L+ E7 D9 y<td nowrap="nowrap"> <input type="checkbox" name="shirt" value="medium" checked="checked">
( [- x4 w1 b9 O8 I9 |4 o, O9 C7.不要在注释内容中使“--”+ h) i5 K' Y* g- `6 U% u
“--”只能发生在XHTML注释的开头和结束,也就是说,在内容中它们不再有效。例如下面的代码是无效的:
' {" d4 }& K1 Z4 |<!--这里是注释-----------这里是注释-->
. s; @/ n) X- w用等号或者空格替换内部的虚线。
; u) ^) m$ j+ \, H# r<!--这里是注释============这里是注释--> + g$ J* W3 }" }1 }( k/ K
以上这些规范有的看上去比较奇怪,但这一切都是为了使我们的代码有一个统一、唯一的标准,便于以后的数据再利用。 |
|