过期域名预定抢注

 找回密碼
 免费注册

怎麼改善現有網站為xhtml+CSS結構

  [複製鏈接]
發表於 2006-8-10 20:08:48 | 顯示全部樓層 |閱讀模式
我們大部分的設計師依舊在採用傳統的表格佈局、表現與結構混雜在一起的方式來建立網站。學習使用XHTML+CSS的方法需要一個過程,使現有網站符合網站標準也不可能一步到位。最好的方法是循序漸進,分階段來逐步達到完全符合網站標準的目標。如果你是新手,或者對代碼不是很熟悉,也可以採用遵循標準的編輯玩具,例如Dreamweaver MX 2004,它是目前支持CSS標準最完善的玩具。
: P# f* n1 B6 ~9 F* B+ @0 M# V  R$ O
1.初級改善6 d0 }2 W, t. t5 A
為頁面添加正確的DOCTYPE % `: F2 c. m& m
很多設計師和開發者都不知道什麼是DOCTYPE,DOCTYPE有什麼用。DOCTYPE是document type的簡寫。主要用來說明你用的XHTML或者HTML是什麼版本。瀏覽器根據你DOCTYPE定義的DTD(文檔類型定義)來解釋頁面代碼。所以,如果你不注意設置了錯誤的DOCTYPE,結果會讓你大吃一驚。XHTML1.0提供了三種DOCTYPE可選擇:
. K" `2 a; h" }# i) C% E
- E" i% u' R* X" k* Y3 i5 b(1)過渡型(Transitional )
- D; {# C4 Q8 o  V) @
+ Z3 i) _" Q9 U$ M, B<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
/ _( y) a4 }# c# K(2)嚴格型(Strict )
( t. d. x+ k# }% D* ~6 ~% P2 i9 ?. B& O
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
- `9 V8 [5 s# f$ b3 L' o(3)框架型(Frameset )8 g5 C2 ~* e6 K5 z9 j/ Q7 h! S

% T5 a2 d* h! {9 @: _<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> 1 q& h3 V5 c$ w$ j- J2 C! [4 Z3 |
對於我們初級改善來說,只要選用過渡型的聲明就可以了。它依然可以兼容你的表格佈局、表現標識等,不至於讓你覺得變化太大,難以掌握。( q* v7 j3 R! Z. ~, c! v+ k  w
$ L1 I: @7 H# S! H% x- H
Tip:你懶得輸入上面過渡型代碼的話,可以訪問http://www.macromedia.com/網站的首頁,然後查看源代碼,把head區同樣的代碼拷貝粘貼就可以了。: i: d+ W" \6 Q3 Q& a0 ?; q
. V, e8 p- b  V( d4 D" e3 T6 k" W( l
設定一個名字空間(Namespace) 9 }: a1 k  e7 c5 X2 V1 z
直接在DOCTYPE聲明後面添加如下代碼:7 r5 e* A7 C) r0 N. P8 p
6 |+ T+ l6 _4 h  ?8 [' f' _- {+ U
<html XMLns="http://www.w3.org/1999/xhtml" >
% [( h% t: ?' T% X2 ^一個namespace是收集元素類型和屬性名字的一個詳細的DTD,namespace聲明允許你通過一個在線地址指向來識別你的namespace。只要照樣輸入代碼就可以。$ S* x2 e: V6 g+ S; F4 m& z2 s
) c% t0 |" E5 j- c# S7 k8 O
聲明你的編碼語言
* `% T- ^5 J) W/ u; W  _7 }; q為了被瀏覽器正確解釋和通過標識校驗,所有的XHTML文檔都必須聲明它們所使用的編碼語言。代碼如下:# u9 R4 U9 h" g

3 o: O( G1 w6 H  r& d# y<meta http-equiv="Content-Type" content="text/html; charset=GB2312" />
2 O6 J. F# i0 F' y- l1 G2 J這裡聲明的編碼語言是簡體中文GB2312,你如果需要製作繁體內容,可以定義為BIG5。
4 K9 Y0 s/ c8 g6 D" w! @4 D7 q5 P% g4 V# @9 I& d" x+ r
用小寫字母書寫所有的標籤
3 e+ B5 [1 q7 U/ Q% W6 aXML對大小寫是敏感的,所以,XHTML也是大小寫有區別的。所有的XHTML元素和屬性的名字都必須使用小寫。否則你的文檔將被W3C校驗認為是無效的。例如下面的代碼是不正確的:- E) |9 r" O4 P5 K. s* k
; v7 ~2 I$ J: B' T9 _. Y, e
<TITLE>公司簡介</TITLE>
9 c$ q' M" U7 Z. h4 v/ y0 e正確的寫法是:
- i! H0 w  v- s. I  t
% H: p. O2 S5 m! t) F, E<title>公司簡介</title> 同樣的,<P>改成<p>,<B>改成<b>等等。這步轉換很簡單。 ) o6 `4 P0 I; \% n9 ]
為圖片添加 alt 屬性
; k& |4 g9 p+ H" g: j為所有圖片添加alt屬性。alt屬性指定了當圖片不能顯示的時候就顯示供替換文本,這樣做對正常用戶可有可無,但對純文本瀏覽器和使用屏幕閱讀機的用戶來說是至關重要的。只有添加了alt屬性,代碼才會被W3C正確性校驗通過。注意的是我們要添加有意義的alt屬性,像下面這樣的寫法毫無意義:+ I9 v% h. b9 S7 O& }( o" {
0 M% i4 X8 p, r4 @! K; c% s, U% a
<img src="logo_unc_120x30.gif" alt="logo_unc_120x30.gif"> 2 x4 R! d6 A4 u: n/ Z0 D
正確的寫法:
/ o7 I+ W/ [' z8 a" X
2 v8 J6 ]4 K$ {, y( N& a; z+ ]$ i) I<img src="logo_unc_120x30.gif" alt="UNC公司標誌,點擊返回首頁">
$ }* v# x, M8 V# m2 x給所有屬性值加引號 2 t. ?* x, b' s1 N' g( i
在HTML中,你可以不需要給屬性值加引號,但是在XHTML中,它們必須被加引號。5 L) }, i7 E# U# X0 n. p4 J

; v# U7 l0 _% m1 [: t) ^例:height="100",而不能是height=100。
4 r# m2 b. y! h2 _' c7 r0 L6 ^2 q$ f" f* I& w( |  I/ _" {
關閉所有的標籤 # z2 z0 G/ h5 n% u" M% N9 G
在XHTML中,每一個打開的標籤都必須關閉。就像這樣:
1 c( T% a8 a! _% Y4 |, t' B3 w: k: N5 Q5 y9 I
<p>每一個打開的標籤都必須關閉。</p> <b>HTML可以接受不關閉的標,XHTML就不可以。</b>   U& W! ]% p. V; L0 Z. Q
這個規則可以避免HTML的混亂和麻煩。舉例來說:如果你不關閉圖像標籤,在一些瀏覽器中就可能出現CSS顯示問題。用這種方法能確保頁面和你設計的一樣顯示。需要說明的是:空標籤也要關閉,在標籤尾部使用一個正斜槓"/"來關閉它們自己。例如:9 d3 T8 ^% z' n  `
* t! F$ U' b' ]' C4 F- J
<br /> <img src="webstandards.gif" />
; }; R$ h+ L# v. t經過上述七個規則處理後,頁面就基本符合XHTML1.0的要求。但我們還需要校驗一下是否真的符合標準了。我們可以利用W3C提供免費校驗服務(http://validator.w3.org/)。發現錯誤後逐個修改。在後面的資源列表中我們也提供了其他校驗服務和對校驗進行指導的網址,可以作為W3C校驗的補充。當最後通過了XHTML驗證,恭喜你已經向網站標準邁出了一大步。不是想像中的那麼難吧!/ l6 E+ W$ j7 W4 Z! W% P4 S! j
& G4 x% g3 w) Q* E$ _
2.中級改善
- p2 J9 T* K! `$ `! n$ X接下來我們的改善主要在結構和表現相分離上,這一步不像第一步那麼容易實現,我們需要觀念上的轉變,以及對CSS2技術的學習和運用。但學習任何新知識都需要花點時間的,不是嗎?訣竅在於邊做邊學。假如你一直採用表格佈局,根本沒用過 CSS,也不必急於跟表格佈局說再見,你可以先用樣式表代替 font 標籤。隨著你學到的越多,你能做的就越多。好,一起來看看我們需要做哪些事:' s& E* M8 o. j! P6 T
9 R! _! V- m& p  R/ V' }
用CSS定義元素外觀 ( K: ]; b- t0 ?! c$ r  y
我們在寫標識時已經養成習慣,當希望字體大點就用<h1>,希望在前面加個點符號就用<li>。我們總是想<h1>的意思是大的,<li>的意思是圓點,<b>的意思是「加粗文本」。而實際上, <h1>能變成你想要的任何樣子,通過CSS,<h1>能變成小的字體,<p>文本能夠變成巨大的、粗體的,<li>能夠變成一張圖片等等。我們不能強迫用結構元素實現表現效果,我們應該使用CSS來確定那些元素的外觀。例如,我們可以使原來默認的6級標題可以看起來大小一樣:# t3 ^9 g1 g) b/ P! \
1 R, l+ W7 D% R0 w: A& n
h1, h2, h3, h4, h5, h6{ font-family: 細明體, serif; font-size: 12px; }
. x: ]- \+ t% M, X用結構化元素代替無意義的垃圾 1 s. C' j8 f# Y. Z  z; o
許多人可能從來都不知道HTML和XHTML元素設計本意是用來表達結構的。我們很多人已經習慣用元素來控制表現,而不是結構。例如,一段列表內容可能會使用下面這樣的標識:
" h6 q: o! G' L" H* C' r" l! F0 M7 X
句子一<br /> 句子二<br /> 句子三<br /> + ]9 Z- M+ O5 n& p$ A. V5 ]; j
如果我們採用一個無序列表代替會更好:! ]: i: y7 x0 K( R0 e8 g% b8 Z
) f& [" w8 I6 N7 V, S4 Z
<ul> <li>句子一</li> <li>句子二</li> <li>句子三</li> </ul> + e  e) R/ n8 k# t4 G$ S9 D
你或許會說「但是<li>顯示的是一個圓點,我不想用圓點」。事實上,CSS沒有設定元素看起來是什麼樣子,你完全可以用CSS關掉圓點。
: ?2 |' {9 h  ]
: q+ a& J2 r3 G( J/ w9 e給每個表格和表單加上id + n4 _" K* Z, ~. p% d: e
給表格或表單賦予一個唯一的、結構的標記,例如
8 J! H, Z9 u, |! Z6 V
1 u2 S3 r' b1 Z5 f1 ?/ \1 h<table id="menu">
7 ?" g  n% z* H1 D) d接下來,在書寫樣式表的時候,你就可以創建一個「menu」的選擇器,並且關聯一個CSS規則,用來告訴表格單元、文本標籤和所有其他元素怎麼去顯示。這樣,不需要對每個<td>標籤附帶一些多餘的、佔用帶寬的表現層的高、寬、對齊和背景顏色等等屬性。只需要一個附著的標記(標記「menu」的id標記),你就可以在一個分離的樣式表內為乾淨的、緊湊的代碼標記進行特別的表現層處理。
& H( p8 \8 w& k) V. l, Q/ @/ x) t+ f$ F
中級改善我們這裡先列主要的三點,但其中包含的內容和知識點非常多,需要我們逐步學習和掌握,直到最後實現完全採用CSS而不才用任何表格實現佈局。
 樓主| 發表於 2006-8-10 20:10:19 | 顯示全部樓層
怎麼改善現有網站為xhtml+CSS結構——我們大部分的設計師依舊在採用傳統的表格佈局、表現與結構混雜在一起的方式來建立網站。' a3 b/ m1 o1 p1 \) a9 o! V

& }6 O- ?2 t6 P, h7 c% ~! E$ ^  W
0 R# l! V* i! C/ Y1 [8 N5 C 2 J* h9 D/ J! |/ ~8 \$ Z: @1 g

% V* c$ n, j: |5 x4 f
) X# N5 b1 F5 G5 z2 W' } # \) V& y6 a. I5 C1 P* C
. m* N$ ]' h7 ^6 d
CSS本身沒有直接提供變換HTML鏈接下劃線的功能,但只要運用一些技巧,我們還是可以讓單調的網頁鏈接下劃線變得豐富多彩。
: G& Z5 K& `% E' t) U$ _- F' z" y8 H# n+ Q. \% D1 v. X; P
  一、基本原理 6 t7 w: N$ i) x- }+ A
  首先,自定義HTML鏈接下劃線的第一步是創建一個圖形,在水平方向重複放置這個圖形即形成下劃線效果。如果要顯示出下劃線背後的網頁背景,可以使用透明的.gif圖形。3 h0 C  [7 c! y) }' v/ e& w$ x" l' g
  其次,如果下劃線圖形的高度較大,則必須適當增加文本的高度,使得一行文本的底部與下一行文本的頂部之間有較大的空間,例如p { line-height: 1.5; }。
0 r: @) d# ?9 _" @  c: g3 f) y) n( y0 o, ?, ^; M2 J
自定義鏈接下劃線示例
, w0 z3 g8 e5 s- r  第三,為顯示出自定義的下劃線,必須隱藏默認的下劃線,即a { text-decoration: none; }。
; f. }9 W/ E, k% R" [2 Q/ q  第四,為鏈接元素設置下劃線圖形,構造出自定義的下劃線。假設下劃線圖形是underline.gif,則設置下劃線圖形的CSS代碼為a { background-image: url(underline.gif); }。
9 I$ k& e* @8 u) b. o3 P' c6 t  第五,我們要讓下劃線圖形在水平方向反覆出現,但不能在垂直方向重複出現,否則它將被隱藏到文本的背後。要求下劃線只在水平方向重複出現的代碼為:a { background-repeat: repeat-x; }。. ^5 I  s! O8 `4 k: @# f
  第六,為保證圖形出現在鏈接文字的下方(不管字體的大小),用background-position屬性將圖形放在鏈接元素的底部。對於箭頭之類的下劃線圖形,可能還要考慮圖形在水平方向的對齊方向。假設要將下劃線圖形放在右下角,CSS代碼為:a { background-position: 100% 100%; }。
6 s: N5 Y9 ]# X  d/ w' h) N  第七,為了在鏈接文本的下方給自定義圖形留出空間,必須加入適當的空白。下劃線圖形相對於鏈接文字的具體位置與文字的大小有關,但一般而言,可以先讓底部空白等於下劃線圖形的高度,必要時再作調整。例如:a { padding-bottom: 4px; }。2 C- h0 P: S4 l8 v; a, x
  第八,由於下劃線圖形放在鏈接元素的底部,必須保證鏈接不折行(如允許鏈接跨越多個行,則只有下面一行的鏈接文本下面會有自定義的下劃線)。用CSS的white-space屬性可以防止鏈接文字折行,即a { white-space: nowrap; }。, h) n* U# L! f+ v* M
  綜上所述,為鏈接元素定義CSS樣式屬性的完整例子如:
8 \) z1 d2 Q0 {, _8 C) U  a {! n9 `+ Z# C7 D3 t8 ~
   text-decoration: none;
( N4 w9 d& U7 q0 {* l8 H1 a   background: url(underline.gif) repeat-x 100% 100%;  f2 u+ ?  j! S1 K) |
   padding-bottom: 4px;# W) E. D5 [8 Q+ q& X
   white-space: nowrap;/ ^+ z5 s( s7 u9 s- H( n. ^7 w7 u
  } & w8 {1 V! e, o! o

: _5 k, Z/ ]: E& s' `, O( x  如果要讓自定義下劃線只在鼠標停留時出現,只要把原來直接設置在鏈接元素上的CSS background屬性改到:hover ,例如:
! R3 }+ r; Z  Q& ]  a {
1 {  L, _7 _4 Q1 V   text-decoration: none;4 r/ l6 ]- |- e& F+ O
   padding-bottom: 4px;2 T0 ?% W% g! W: P
   white-space: nowrap;
, t: f7 z& B3 s, n  }
- M$ v; z0 o( v8 [9 b: y5 u) D9 ?- i3 o  a:hover {
, K/ I  d& y) A. W/ a   background: url(underline.gif) repeat-x 100% 100%;8 c# ~" A# l5 N
  }
/ z" _, X5 M  f9 e
  o0 o! F( |" e# [  二、實例欣賞   `! k$ i" m7 W+ A1 {; u
  假設有兩個下劃線圖形diagonal.gif(波紋線)、flower.gif(花朵)前者的高、寬是3、9,後者的高、寬是11、15。下面是一個設置兩種下劃線的完整實例:& D( s) D$ X: E! L

- t. x. b: B9 E3 |1 L0 r5 |! ]自定義鏈接下劃線舉例8 K- |8 X6 _4 h5 d' C& C5 V
  網頁源代碼如下:
/ K" q- V, }2 _; F8 p2 I  g9 m  註:diagonal.gif 和 flower.gif已經先拷貝到網頁所在的同一目錄下。6 J9 N4 R' O4 n: M" H) h' P1 k( ]
  <html>7 m% x- X: H* `; D
  <head>
5 [, S( ^$ t4 n: o1 o  <title>ex</title>/ ?. I# x2 j7 R
  <style type="text/css">
+ M7 X/ s; g: J5 f/ k: s  a#example1a {
  }6 y2 @4 M$ A4 ?4 G: g6 C) i    text-decoration: none;) C. O0 @- `: o4 Y8 J8 N
    background: url(diagonal.gif) repeat-x 100% 100%;8 a8 u3 t$ t% e7 d: j
    white-space: nowrap;4 q, E7 J" `' {! c  X9 {
    padding-bottom: 2px;
/ t3 O. T/ t) _& C1 u) e    }+ i8 W2 U3 }. t/ A0 k0 M0 {
  a#example1b {
! e; m4 I8 k9 f/ c1 ~    text-decoration: none;
. |# l+ f' X/ D    white-space: nowrap;) y  V6 G3 J: z7 @7 M
    padding-bottom: 2px;
9 f' l- {: B) Q6 @7 I    }
* J" P/ @/ i; j/ n; F2 i  a#example1b:hover {
0 M3 G+ i/ C) H; E( p+ l* E    background: url(diagonal.gif) repeat-x 100% 100%;  V. @- \# G8 f' x2 }1 \# N4 ^9 o
    }& v3 _6 ?' v3 h' D5 m
  a#example2a {
0 S/ l# d' o! t    text-decoration: none;: F$ n- f1 B: L2 d6 ~- i
    background: url(flower.gif) repeat-x 100% 100%;
/ d: ?) b# @  \. e  J; X1 k1 p- d    white-space: nowrap;, l' ]( R7 `7 h) ?4 X
    padding-bottom: 10px;
' J7 k, K' i, t) A  k3 @7 [! g1 L    }( l( i3 t* ]1 X# ^
  a#example2b {. N" E0 c1 Q2 J* }& v
    text-decoration: none;, w! B+ a. f4 _- p* v
    white-space: nowrap;
  o$ Z9 s  b/ M; M8 _6 H$ j0 O+ Z    padding-bottom: 10px;5 l# X( Y' {; n% B. w
    }
0 O: b% g. z  B# {  a#example2b:hover {" |( K  g. R7 @+ }- W- Z, U7 J
    background: url(flower.gif) repeat-x 100% 100%;: U1 O; w% J2 e- _0 k+ O2 u
    }
& W/ P& j9 Z- y7 J  -->
0 O, ~8 E7 v) g  </style>
) F9 S( v3 H% O5 F! x2 d! U  </head>
9 w7 k+ E; q. G" q, }, L  <body>  q' a- ^( ^* r& S- H4 }
  <p>實例:</p>
4 h( J" K  c; _; r& A2 \  <p> <a href="#" id="example1a">波紋線靜態下劃線</a>,3 B# F  m$ V+ [0 @
  <a href="#" id="example1b">鼠標停留時出現的波紋線</a>。</p>: b+ l$ S0 ]' `: _. u
  <p> <a href="#" id="example2a">花朵靜態下劃線</a>,
3 b; O8 i- k3 x  <a href="#" id="example2b">鼠標停留時出現的花朵下劃線</a>。</p>
' C8 x, e2 |7 l1 [  </body>" K. t% Q7 {. q: O) L- _
  </html>
回復 给力 爆菊

使用道具 舉報

發表於 2006-8-10 20:25:39 | 顯示全部樓層
再多點,繼續啊。最近正用GOLIVE做div方面的東東。s
回復 给力 爆菊

使用道具 舉報

發表於 2006-9-18 15:09:37 | 顯示全部樓層
提示: 作者被禁止或刪除 內容自動屏蔽
回復 给力 爆菊

使用道具 舉報

發表於 2011-9-8 11:38:35 | 顯示全部樓層
太複雜了,學習一下,支持支持
回復 给力 爆菊

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 免费注册

本版積分規則

點基跨境 數位編輯創業論壇

GMT+8, 2025-7-15 04:19

By DZ X3.5

小黑屋

快速回復 返回頂部 返回列表