DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> CSS入門知識 >> CSS詳解 >> target=_blank不符合標准?
target=_blank不符合標准?
編輯:CSS詳解     

本文參考了以下文章:

Kevin Yank的《New-Window Links in a Standards-Compliant World》
《Standards-based Replacement for target="_blank" in External Links》
我們要在新窗口中打開鏈接通常的做法是在鏈接後面加target="_blank",我們采用過渡型的DOCTYPE(xhtml1-transitional. dtd)時沒有問題,但是當我們使用嚴格的DOCTYPE(xHtml1-strict.dtd)時,這個方法將通不過W3C的校驗,會出現如下錯誤提示:

"there is no attribute target for this element(in this Html version)"

原來在HTML4.01/XHTML1.0/XHtml1.1嚴格DOCTYPE下,target="_blank"、target="_self"等等語法都是無效的,我們只能通過JavaScript來變通實現。

有朋友問為什麼不允許使用target="_blank"?這個屬性很方便啊。呵呵,不知道W3C的專家們是怎麼想的,據我所知,主要是“易用性、友好性”的問題,因為老外覺得不經過用戶同意,沒有明確提示就打開一個新窗口是不禮貌的。先不管這個取消是否合理,我們來看看解決辦法。

rel屬性
Html4.0增加了一個新屬性:rel,這個屬性用來說明鏈接和包含此鏈接頁面的關系,以及鏈接打開的目標。rel有許多的屬性值,比如next、previous,、chapter、section等等。我們要使用的就是rel="external"屬性。原來這樣寫的代碼:

<a href="document.Html" target="_blank">打開一個新窗口</a>
現在要寫成這樣:

<a href="document.Html" rel="external">打開一個新窗口</a>
這是符合strict標准的方法。當然還必須配合一個Javascript才有效。

Javascript
完整的代碼JS如下:

function externalLinks() {
if (!document.getElementsByTagName) return;
var anchors = document.getElementsByTagName("a");
for (var i=0; i var anchor = anchors[i];
if (anchor.getAttribute("href") &&
anchor.getAttribute("rel") == "external")
anchor.target = "_blank";
}
}
window.onload = externalLinks;
你可以把它保存成一個.js文件(比如external.JS),然後通過外部聯接方法調用:

<script type="text/Javascript" src="external.JS"></script>
就是這樣。

最後補充一句,我網站采用的target="new"在過渡型DOCTYPE下是允許的,但也不符合strict標准。下次改版時我將采用strict模式,將所有target="new"改成rel="external"。
http://www.cnfreelancer.Net/blog/article.ASP?id=82

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved