我們大部分的設計師依舊在採用傳統的表格佈局、表現與結構混雜在一起的方式來建立網站。學習使用XHTML+CSS的方法需要一個過程,使現有網站符合網站標準也不可能一步到位。最好的方法是循序漸進,分階段來逐步達到完全符合網站標準的目標。如果你是新手,或者對代碼不是很熟悉,也可以採用遵循標準的編輯玩具,例如Dreamweaver MX 2004,它是目前支持CSS標準最完善的玩具。' e1 ^5 |; O j1 G
! G1 E; R5 _+ |/ g1.初級改善6 x" ^ S' h7 g$ k$ o
為頁面添加正確的DOCTYPE % t( z- y" d" }& m! l8 v
很多設計師和開發者都不知道什麼是DOCTYPE,DOCTYPE有什麼用。DOCTYPE是document type的簡寫。主要用來說明你用的XHTML或者HTML是什麼版本。瀏覽器根據你DOCTYPE定義的DTD(文檔類型定義)來解釋頁面代碼。所以,如果你不注意設置了錯誤的DOCTYPE,結果會讓你大吃一驚。XHTML1.0提供了三種DOCTYPE可選擇:
/ `' }% S) ]- x. A3 T
* C) O! C1 L; z7 I4 a4 n(1)過渡型(Transitional )4 |3 g8 x9 j3 i$ l$ h
$ C0 H8 Z: z+ }6 K+ j! T
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5 ~. X" W4 |. u# @" }(2)嚴格型(Strict )
/ |5 C( q" T# M# n) Z0 E
8 ^( I/ Y% S! k/ z<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
* P8 c/ y0 A. B; _/ X# j(3)框架型(Frameset )
# a1 z" [) D* z* I
+ ?. u6 C' D: k- ?& W* u5 y<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> 3 c+ I: c& d9 K6 T7 X% o! g2 a
對於我們初級改善來說,只要選用過渡型的聲明就可以了。它依然可以兼容你的表格佈局、表現標識等,不至於讓你覺得變化太大,難以掌握。
/ H6 U( w+ \9 t) F
! w! o6 w+ ?( f1 {- zTip:你懶得輸入上面過渡型代碼的話,可以訪問http://www.macromedia.com/網站的首頁,然後查看源代碼,把head區同樣的代碼拷貝粘貼就可以了。
/ Y# S" Q" X1 e, ^4 q" l
7 q: O y2 o' O8 E設定一個名字空間(Namespace)
9 U' X: R8 z, Y# _# `8 N直接在DOCTYPE聲明後面添加如下代碼:
6 K$ Q7 R3 c* `! s
' J2 T4 ?% A6 }& O9 l# T<html XMLns="http://www.w3.org/1999/xhtml" > 3 _; F# g' V7 G+ y) t! w
一個namespace是收集元素類型和屬性名字的一個詳細的DTD,namespace聲明允許你通過一個在線地址指向來識別你的namespace。只要照樣輸入代碼就可以。
: g6 I6 I$ s8 y# q: i) S+ O& P$ ~% H5 M( Q9 n h9 `+ @& }
聲明你的編碼語言 - J; @' N; T" `. a1 A6 W! X
為了被瀏覽器正確解釋和通過標識校驗,所有的XHTML文檔都必須聲明它們所使用的編碼語言。代碼如下:
6 E3 h2 W6 ~; s+ g0 S1 G" s2 \
2 s, R; _( m9 f<meta http-equiv="Content-Type" content="text/html; charset=GB2312" /> " j" z* q7 O% e9 R+ K X
這裡聲明的編碼語言是簡體中文GB2312,你如果需要製作繁體內容,可以定義為BIG5。
4 L2 _4 y6 t9 v8 v/ N3 F$ J0 A: g6 R% z( c! D
用小寫字母書寫所有的標籤 # I$ O$ Y9 O8 a
XML對大小寫是敏感的,所以,XHTML也是大小寫有區別的。所有的XHTML元素和屬性的名字都必須使用小寫。否則你的文檔將被W3C校驗認為是無效的。例如下面的代碼是不正確的:
+ z/ r% C) d' L# N
; l }/ U- L. S: f1 _1 U% v* @% y<TITLE>公司簡介</TITLE>
, S; |0 W# a6 d, `. S正確的寫法是:" w7 O7 I, ^, r$ e
) k) C! [& n$ z& x' M2 k
<title>公司簡介</title> 同樣的,<P>改成<p>,<B>改成<b>等等。這步轉換很簡單。
8 A6 S: E: Y( A4 C為圖片添加 alt 屬性
; j/ a- J; ^0 S8 R為所有圖片添加alt屬性。alt屬性指定了當圖片不能顯示的時候就顯示供替換文本,這樣做對正常用戶可有可無,但對純文本瀏覽器和使用屏幕閱讀機的用戶來說是至關重要的。只有添加了alt屬性,代碼才會被W3C正確性校驗通過。注意的是我們要添加有意義的alt屬性,像下面這樣的寫法毫無意義:
/ L/ L, \: A; u' K+ r# }6 l0 Q& h$ M) q0 u+ X
<img src="logo_unc_120x30.gif" alt="logo_unc_120x30.gif">
* e1 j) x0 _2 y* c4 r0 G( ^. _正確的寫法:
' ^) t" x& {+ C; t) U2 i5 Z. h+ C9 s
8 M* ?- E1 J* _3 p<img src="logo_unc_120x30.gif" alt="UNC公司標誌,點擊返回首頁"> & w5 }6 n4 s" N( G+ f9 d
給所有屬性值加引號 8 m# Z7 v. T0 n/ {, H" y
在HTML中,你可以不需要給屬性值加引號,但是在XHTML中,它們必須被加引號。
, A1 U) J0 P+ _( P
: ^1 ~$ f @6 @$ c5 k$ A例:height="100",而不能是height=100。0 \& l0 d) b `& @4 F3 J( u) i
9 j4 Z$ ^; ? {; d
關閉所有的標籤
1 |7 b1 m) x y8 a) ~& O( A& l在XHTML中,每一個打開的標籤都必須關閉。就像這樣:4 F3 K6 V1 Z" x9 l# N
4 q/ }% a: t" L7 u7 F8 v9 I8 [* L5 ^
<p>每一個打開的標籤都必須關閉。</p> <b>HTML可以接受不關閉的標,XHTML就不可以。</b>
# h) D8 u9 C' Q; |這個規則可以避免HTML的混亂和麻煩。舉例來說:如果你不關閉圖像標籤,在一些瀏覽器中就可能出現CSS顯示問題。用這種方法能確保頁面和你設計的一樣顯示。需要說明的是:空標籤也要關閉,在標籤尾部使用一個正斜槓"/"來關閉它們自己。例如:+ j6 T- z* x& v ]6 }# L
j5 V/ L9 C7 b* G
<br /> <img src="webstandards.gif" /> ' l+ w' N: s* ~9 c, \
經過上述七個規則處理後,頁面就基本符合XHTML1.0的要求。但我們還需要校驗一下是否真的符合標準了。我們可以利用W3C提供免費校驗服務(http://validator.w3.org/)。發現錯誤後逐個修改。在後面的資源列表中我們也提供了其他校驗服務和對校驗進行指導的網址,可以作為W3C校驗的補充。當最後通過了XHTML驗證,恭喜你已經向網站標準邁出了一大步。不是想像中的那麼難吧!- H& |" Y7 X8 O4 G
6 r* b! {. ?; ^* H
2.中級改善
" J4 k- p) D/ O1 ~接下來我們的改善主要在結構和表現相分離上,這一步不像第一步那麼容易實現,我們需要觀念上的轉變,以及對CSS2技術的學習和運用。但學習任何新知識都需要花點時間的,不是嗎?訣竅在於邊做邊學。假如你一直採用表格佈局,根本沒用過 CSS,也不必急於跟表格佈局說再見,你可以先用樣式表代替 font 標籤。隨著你學到的越多,你能做的就越多。好,一起來看看我們需要做哪些事:9 o+ K8 A& p; R; z( p5 B
7 [6 r! U9 a. ]) ?3 g- x
用CSS定義元素外觀 4 H. q( _0 v0 @( @$ j
我們在寫標識時已經養成習慣,當希望字體大點就用<h1>,希望在前面加個點符號就用<li>。我們總是想<h1>的意思是大的,<li>的意思是圓點,<b>的意思是「加粗文本」。而實際上, <h1>能變成你想要的任何樣子,通過CSS,<h1>能變成小的字體,<p>文本能夠變成巨大的、粗體的,<li>能夠變成一張圖片等等。我們不能強迫用結構元素實現表現效果,我們應該使用CSS來確定那些元素的外觀。例如,我們可以使原來默認的6級標題可以看起來大小一樣:7 S7 j. i9 {( Y+ c) t
9 a6 b7 m# m* O1 `" v
h1, h2, h3, h4, h5, h6{ font-family: 細明體, serif; font-size: 12px; } + b4 t4 C4 i% w3 s+ P$ A
用結構化元素代替無意義的垃圾 2 C" B3 ~7 U+ K; C6 I
許多人可能從來都不知道HTML和XHTML元素設計本意是用來表達結構的。我們很多人已經習慣用元素來控制表現,而不是結構。例如,一段列表內容可能會使用下面這樣的標識:) }) }( p: I5 I, m4 k Y: T- X
& D# j, V& S7 U9 E6 P8 {# S0 r" g句子一<br /> 句子二<br /> 句子三<br /> / L3 N8 }! z% a* S, {
如果我們採用一個無序列表代替會更好:4 {# {/ P. r% Z" X* m+ G
0 m! `# N H) ^1 u7 S
<ul> <li>句子一</li> <li>句子二</li> <li>句子三</li> </ul>
$ Y+ t/ z: X: A你或許會說「但是<li>顯示的是一個圓點,我不想用圓點」。事實上,CSS沒有設定元素看起來是什麼樣子,你完全可以用CSS關掉圓點。
6 q# y/ k- L3 Y$ A% d+ |; `
4 ?! \5 c* ~) h: B+ ]給每個表格和表單加上id ( @' b% _5 P( Q- [
給表格或表單賦予一個唯一的、結構的標記,例如2 C0 \( }" N/ g: G* X
8 r+ w! P8 H3 J) w& `$ g4 z
<table id="menu"> + O# L, _2 c( j
接下來,在書寫樣式表的時候,你就可以創建一個「menu」的選擇器,並且關聯一個CSS規則,用來告訴表格單元、文本標籤和所有其他元素怎麼去顯示。這樣,不需要對每個<td>標籤附帶一些多餘的、佔用帶寬的表現層的高、寬、對齊和背景顏色等等屬性。只需要一個附著的標記(標記「menu」的id標記),你就可以在一個分離的樣式表內為乾淨的、緊湊的代碼標記進行特別的表現層處理。5 C# A, E2 k( B
O7 U& Y9 L5 w1 P/ N: l
中級改善我們這裡先列主要的三點,但其中包含的內容和知識點非常多,需要我們逐步學習和掌握,直到最後實現完全採用CSS而不才用任何表格實現佈局。 |
|