網頁開啟新視窗target=_blank不符合標準_經驗交流

來源:互聯網
上載者:User
"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"屬性。原來這樣寫的代碼:


開啟一個新視窗

現在要寫成這樣:開啟一個新視窗

這是符合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),然後通過外部聯結方法調用:

就是這樣。

最後補充一句,我網站採用的target="new"在過渡型DOCTYPE下是允許的,但也不符合strict標準。下次改版時我將採用strict模式,將所有target="new"改成rel="external"。

本文參考了以下文章:

Kevin Yank的《New-Window links in a Standards-Compliant World》
《Standards-based Replacement for target="_blank" in External links》
2006.7.13更新
很多門戶網站的首頁全部是彈出式的,我估計至少在中國這種觀念暫時還改不了,在這種情況下就不需要在每個連結下加rel,全代碼如下:

  • 相關文章

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.