作為網(wǎng)站技術(shù)開發(fā)人員而言,往往是站在自己的開發(fā)角度來實(shí) 施網(wǎng)站布署(讀取數(shù)據(jù)及開發(fā)的方便性等等),而不是站在網(wǎng)站訪問者與搜索引擎角度。因此大部分的網(wǎng)站在瀏覽方面不夠直觀或是方便,特別是現(xiàn)在w3c的規(guī)范,更是在大部分的網(wǎng)站開發(fā)人員腦里一片空白。何況百度 、google、msn、yahoo等搜索引擎更有自己的搜索規(guī)則及判斷網(wǎng)頁等級技術(shù),所以網(wǎng)站要化,化的目的只有一個:符合標(biāo)準(zhǔn),符合蜘蛛爬行的標(biāo)準(zhǔn),更重要的是符合網(wǎng)站訪問者瀏覽的方便及易用性。以下文章中,AB織夢模板網(wǎng)主要通過三個方面來講述有關(guān)W3C!
什么是W3C標(biāo)準(zhǔn)
W3C其實(shí)就是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)的驗(yàn)證?
步驟方法如下:
1、圖片的alt="" 屬性每張圖片都加上,而且對齊屬性用CSS來定義。不加不能通過XHTML 1.0的驗(yàn)證。
2、每個文檔加上DTD聲明。
a) !DOCTYPE html PUBLIC "-//W3C//DTDXHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
去掉后能通過驗(yàn)證,但有警告:No DOCTYPE found! Checking with default XHTML 1.0 Transitional Document Type.
3、RSS的XML通過時其中的域名地址與檢測的地址一致,否則會報(bào)錯。
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è)計(jì)里是允許這樣做的。
那是程序的角度不能相同,CSS上是可以相同的!
之前就是相同的產(chǎn)生問題,后面就改成類引用了!
6、不可省略雙引號或單引號。
a) 這個是指屬性,標(biāo)準(zhǔn)是雙引號~
單引號也能通過驗(yà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)簽代碼中不能含有,采用其它的方法實(shí)現(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)驗(yàn)證的原因
每次修正代碼后要刷新代碼,使它們重新生效——一個小錯誤常常會引發(fā)之后整頁的連串錯誤。因此如果操作不當(dāng),“修正錯誤”也可能引發(fā)更多錯誤。每次修正后使代碼重新生效,這樣就可以確保解決問題。
知道了上面這些基本的異常情況,下面discuz模板網(wǎng)就來看看版面設(shè)計(jì)無效的幾個原因。
1、div 標(biāo)簽未關(guān)閉
這是版面設(shè)計(jì)失效的常見原因之一。當(dāng)我們了解到這是多少的版塊設(shè)計(jì)失效的原因時,總會大吃一驚。開啟的div標(biāo)簽是普遍的版塊設(shè)計(jì)失誤之一,也是難診斷的失誤之一。驗(yàn)證程序有時會指向錯誤的開啟div標(biāo)簽,診斷時就像大海撈針一樣麻煩。
2、麻煩的embed標(biāo)簽
九十年代早期,Microsoft和Netscape的瀏覽器開始能夠辨認(rèn)非標(biāo)準(zhǔn)的字體。遺憾的是這意味著W3C驗(yàn)證程序還不能識別某些關(guān)鍵HTML 標(biāo)簽,如“embed”,即使這些標(biāo)簽已經(jīng)被使用。如果確實(shí)希望得到嚴(yán)格的DOCTYPE(文檔類型)驗(yàn)證,就只能放棄嵌套。
如果同時想要生效的版面設(shè)計(jì)和嵌入式媒體,可以試試Flash Satay方法。
3、不當(dāng)?shù)腄OCTYPE聲明
不聲明DOCTYPE,或者在文件開始錯誤聲明DOCTYPE,也是一個常見錯誤。根據(jù)一般經(jīng)驗(yàn),Strict DOCTYPE是大家追求的級驗(yàn)證。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)站不能驗(yàn)證,很有可能是在代碼的某個地方漏寫了結(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)簽,但如果要求更一點(diǎn)希望得到Strict驗(yàn)證,你會看到很多錯誤。 Align是另一個不可用于版面設(shè)計(jì)的標(biāo)簽??梢試L試用“float”或者“text-align”來代替align轉(zhuǎn)換元素。
6、JavaScript
如果已經(jīng)聲明Strict DOCTYPE,就需要在JavaScript中覆蓋CDATA標(biāo)簽。驗(yàn)證程序的這一方面難倒了很多程序員,因?yàn)榫W(wǎng)站傾向于為廣告和追蹤腳本使用嵌入的 JavaScript。如果用到JavaScript,可以在其前后加上如下標(biāo)簽:
<script type="text/javascript">
/* <![CDATA[ */
// JavaScript here
};
/* ]]> */
</script>
7、圖像需要“alt”屬性
你可能還沒有注意到,圖像也是級驗(yàn)證的潛在絆腳石。除了結(jié)尾斜線,級驗(yàn)證也要求用alt標(biāo)簽來描述圖像,如alt= ”Scary vampire picture”.
搜索引擎也靠alt標(biāo)簽來識別網(wǎng)頁上的圖像,所以無論怎樣加上alt標(biāo)簽總是好的。
8、未知實(shí)體數(shù)據(jù)
實(shí)體數(shù)據(jù)是又一個影響驗(yàn)證的易犯錯誤。我們可以考慮用適當(dāng)?shù)木幋a字符來代替“&”等符號。entire list中列出在XHTML版塊設(shè)計(jì)中可用的適當(dāng)?shù)木幋a字符實(shí)體數(shù)據(jù)。
9、不良嵌套
嵌套就是元素里又包括元素,如下所示:
<div><strong>Sweet!</strong></div>
我們?nèi)菀谆煜短自氐捻樞颉@缭赿iv標(biāo)簽前啟動strong標(biāo)簽,但又先關(guān)閉div標(biāo)簽。這可能不會改變版塊布局,但卻會使你的版塊設(shè)計(jì)失效。
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)簽了。