作為網(wǎng)站技術(shù)開發(fā)人員而言,往往是站在自己的開發(fā)角度來實 施網(wǎng)站布署(讀取數(shù)據(jù)及開發(fā)的方便性等等),而不是站在網(wǎng)站訪問者與搜索引擎角度。因此大部分的網(wǎng)站在瀏覽方面不夠直觀或是方便,特別是現(xiàn)在w3c的規(guī)范,更是在大部分的網(wǎng)站開發(fā)人員腦里一片空白。何況百度 、google、msn、yahoo等專業(yè)搜索引擎更有自己的搜索規(guī)則及判斷網(wǎng)頁等級技術(shù),所以網(wǎng)站要優(yōu)化,優(yōu)化的目的只有一個:符合標(biāo)準(zhǔn),符合蜘蛛爬行的標(biāo)準(zhǔn),更重要的是符合網(wǎng)站訪問者瀏覽的方便及易用性。以下文章中,主要通過三個方面來講述有關(guān)W3C!
什么是W3C標(biāo)準(zhǔn)
W3C其實就是World Wide Web Consortium,全球萬維網(wǎng)聯(lián)盟的簡稱。W3C的主要職責(zé)就是確定未來萬維網(wǎng)的發(fā)展方向,并且制定相關(guān)的推薦(recommendation, 由于W3C是一個民間組織,沒有約束性,因此只提供建議)。HTML4.01規(guī)范建議(HTML4.01 Specification Recommendation)就是由W3C所制定的。它還負(fù)責(zé)制定XML,MathML等其他網(wǎng)絡(luò)語言規(guī)范。
怎樣通過W3C標(biāo)準(zhǔn)的驗證?
步驟方法如下:
1、圖片的alt="" 屬性必須每張圖片都加上,而且對齊屬性用CSS來定義。不加不能通過XHTML 1.0的驗證。
2、每個文檔必須加上DTD聲明。
a) !DOCTYPE html PUBLIC "-//W3C//DTDXHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
去掉后能通過驗證,但有警告:No DOCTYPE found! Checking with default XHTML 1.0 Transitional Document Type.
3、RSS的XML通過時其中的域名地址必須與檢測的地址一致,否則會報錯。
4、標(biāo)簽的鏈接屬性加上JAVASCRIPT事件時必須為#空鏈,不能為javascript:;或javascript:void(null);
5、同一個頁面當(dāng)中,同名的ID會產(chǎn)生沖突。所以以ID定義樣式的必須改成類引用。
<div id="a1">111</div>
<div id="a1">222</div>
如果不用W3C來檢測的話,在CSS設(shè)計里是允許這樣做的。
那是程序的角度不能相同,CSS上是可以相同的!
之前就是相同的產(chǎn)生問題,后面就改成類引用了!
6、不可省略雙引號或單引號。
a) 這個是指屬性,標(biāo)準(zhǔn)是雙引號~
單引號也能通過驗證。
7、標(biāo)簽之間不可錯位嵌套。
<div class="CaseDetaListSS">原文鏈接:<a href='/html/cases/cases_61.html'>官方網(wǎng)站</div></a>
這是不允許的。
8、所有的標(biāo)簽都使用小寫。
9、FLASH的標(biāo)簽代碼中不能含有,必須采用其它的方法實現(xiàn)。
10、所有的標(biāo)簽中含有的屬性必須有值(官方的說法)。
11、標(biāo)簽必須配對完成,單標(biāo)簽必須以/關(guān)閉
12、JS和CSS外部引入文件必須加上類型定義。
13、所有的樣式全部寫在外部文件。用類名定義。在使用的地方引用。
14、頁面上的一些特殊字符必須用HTML代碼來標(biāo)識.如“&”寫成“&“
沒通過W3C 標(biāo)準(zhǔn)驗證的原因
每次修正代碼后要刷新代碼,使它們重新生效——一個小錯誤常常會引發(fā)之后整頁的連串錯誤。因此如果操作不當(dāng),“修正錯誤”也可能引發(fā)更多錯誤。每次修正后使代碼重新生效,這樣就可以確保完全解決問題。
知道了上面這些基本的異常情況,下面discuz模板網(wǎng)就來看看版面設(shè)計無效的幾個原因。
1、div 標(biāo)簽未關(guān)閉
這是版面設(shè)計失效的最常見原因之一。當(dāng)我們了解到這是多少精致的版塊設(shè)計失效的罪魁禍?zhǔn)讜r,總會大吃一驚。開啟的div標(biāo)簽是最普遍的版塊設(shè)計失誤之一,也是最難診斷的失誤之一。驗證程序有時會指向錯誤的開啟div標(biāo)簽,診斷時就像大海撈針一樣麻煩。
2、麻煩的embed標(biāo)簽
九十年代早期,Microsoft和Netscape的瀏覽器開始能夠辨認(rèn)非標(biāo)準(zhǔn)的獨有字體。遺憾的是這意味著W3C驗證程序還不能識別某些關(guān)鍵HTML 標(biāo)簽,如“embed”,即使這些標(biāo)簽已經(jīng)被廣泛使用。如果確實希望得到嚴(yán)格的DOCTYPE(文檔類型)驗證,就只能放棄嵌套。
如果同時想要生效的版面設(shè)計和嵌入式媒體,可以試試Flash Satay方法。
3、不當(dāng)?shù)腄OCTYPE聲明
不聲明DOCTYPE,或者在文件開始錯誤聲明DOCTYPE,也是一個常見錯誤。根據(jù)一般經(jīng)驗,Strict DOCTYPE是大家追求的最高級驗證。Strict validation表明你的網(wǎng)頁能夠在所有瀏覽器上都得到最佳展示。Strict 聲明代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
4、結(jié)尾斜線
如果你的網(wǎng)站不能驗證,很有可能是在代碼的某個地方漏寫了結(jié)尾斜線。我們很容易忽略結(jié)尾斜線之類的東西,特別是在image標(biāo)簽等元素中。例如:
在嚴(yán)格的DOCTYPE中這是無效的。要在img標(biāo)簽結(jié)尾處加上“/”以解決此問題。
<img src="" alt="">
5、Align標(biāo)簽
如果DOCTYPE被設(shè)為Transitional,你就會使用“align”標(biāo)簽,但如果要求更高一點希望得到Strict驗證,你會看到很多錯誤。 Align是另一個不可用于版面設(shè)計的標(biāo)簽。可以嘗試用“float”或者“text-align”來代替align轉(zhuǎn)換元素。
6、JavaScript
如果已經(jīng)聲明Strict DOCTYPE,就需要在JavaScript中覆蓋CDATA標(biāo)簽。驗證程序的這一方面難倒了很多程序員,因為網(wǎng)站傾向于為廣告和追蹤腳本使用嵌入的 JavaScript。如果必須用到JavaScript,可以在其前后加上如下標(biāo)簽:
<script type="text/javascript">
/* <![CDATA[ */
// JavaScript here
};
/* ]]> */
</script>
7、圖像需要“alt”屬性
你可能還沒有注意到,圖像也是高級驗證的潛在絆腳石。除了結(jié)尾斜線,高級驗證也要求用alt標(biāo)簽來描述圖像,如alt= ”Scary vampire picture”.
搜索引擎也靠alt標(biāo)簽來識別網(wǎng)頁上的圖像,所以無論怎樣加上alt標(biāo)簽總是好的。
8、未知實體數(shù)據(jù)
實體數(shù)據(jù)是又一個影響驗證的易犯錯誤。我們可以考慮用適當(dāng)?shù)木幋a字符來代替“&”等符號。entire list中列出在XHTML版塊設(shè)計中可用的適當(dāng)?shù)木幋a字符實體數(shù)據(jù)。
9、不良嵌套
嵌套就是元素里又包括元素,如下所示:
<div><strong>Sweet!</strong></div>
我們?nèi)菀谆煜短自氐捻樞?。例如在div標(biāo)簽前啟動strong標(biāo)簽,但又先關(guān)閉div標(biāo)簽。這可能不會改變版塊布局,但卻會使你的版塊設(shè)計失效。
10、缺少“title”標(biāo)簽
盡管這看上去是一個很明顯的錯誤,很多程序員(包括我自己)還是經(jīng)常會在“head”版塊中遺漏title標(biāo)簽。當(dāng)你看到“missing a required sub-element of HEAD”(缺少HEAD的必要子元素)時,才會發(fā)現(xiàn)自己忘記添加title標(biāo)簽了。