不符合web標(biāo)準(zhǔn)的target="_blank"標(biāo)簽_XHTML教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
我們要在新窗口中打開鏈接傳統(tǒng)的通常做法是在鏈接后面加target="_blank",我們采用過渡型的DOCTYPE(xhtml1-transitional. dtd)時(shí)沒有問題,但是當(dāng)我們使用嚴(yán)格的DOCTYPE(xhtml1-strict.dtd)時(shí),這個(gè)方法將通不過W3C的校驗(yàn),會出現(xiàn)如下錯(cuò)誤提示:
原來在HTML4.01/XHTML1.0/XHTML1.1嚴(yán)格DOCTYPE下,target="_blank"、target="_self"等等語法都是無效的,我們只能通過JavaScript來變通實(shí)現(xiàn)。
有朋友問為什么不允許使用target="_blank"?這個(gè)屬性很方便啊。呵呵,不知道W3C的專家們是怎么想的,據(jù)我所知,主要是“易用性、友好性”的問題,因?yàn)槔贤庥X得不經(jīng)過用戶同意,沒有明確提示就打開一個(gè)新窗口是不禮貌的。先不管這個(gè)取消是否合理,我們來看看解決辦法。
rel屬性
HTML4.0增加了一個(gè)新屬性:rel,這個(gè)屬性用來說明鏈接和包含此鏈接頁面的關(guān)系,以及鏈接打開的目標(biāo)。rel有許多的屬性值,比如next、previous,、chapter、section等等。我們要使用的就是rel="external"屬性。原來這樣寫的代碼:
<a href="document.html" target="_blank">打開一個(gè)新窗口</a>
現(xiàn)在要寫成這樣:
<a href="document.html" rel="external">打開一個(gè)新窗口</a>
這是符合strict標(biāo)準(zhǔn)的方法。當(dāng)然還必須配合一個(gè)javascript才有效。
javascript
完整的代碼JS如下:
你可以把它保存成一個(gè).js文件(比如external.js),然后通過外部聯(lián)接方法調(diào)用:
最后補(bǔ)充,標(biāo)簽target="new"在過渡型DOCTYPE下是允許的,但也不符合strict標(biāo)準(zhǔn)。
將所有target="new"改成rel="external"則是完全符合標(biāo)準(zhǔn)的標(biāo)簽!
本文參考了以下文章:Kevin Yank的《New-Window Links in a Standards-Compliant World》
《Standards-based Replacement for target="_blank" in External Links》
示例代碼 [hl5o.cn]
"there is no attribute target for this element(in this HTML version)"
原來在HTML4.01/XHTML1.0/XHTML1.1嚴(yán)格DOCTYPE下,target="_blank"、target="_self"等等語法都是無效的,我們只能通過JavaScript來變通實(shí)現(xiàn)。
有朋友問為什么不允許使用target="_blank"?這個(gè)屬性很方便啊。呵呵,不知道W3C的專家們是怎么想的,據(jù)我所知,主要是“易用性、友好性”的問題,因?yàn)槔贤庥X得不經(jīng)過用戶同意,沒有明確提示就打開一個(gè)新窗口是不禮貌的。先不管這個(gè)取消是否合理,我們來看看解決辦法。
rel屬性
HTML4.0增加了一個(gè)新屬性:rel,這個(gè)屬性用來說明鏈接和包含此鏈接頁面的關(guān)系,以及鏈接打開的目標(biāo)。rel有許多的屬性值,比如next、previous,、chapter、section等等。我們要使用的就是rel="external"屬性。原來這樣寫的代碼:
<a href="document.html" target="_blank">打開一個(gè)新窗口</a>
現(xiàn)在要寫成這樣:
<a href="document.html" rel="external">打開一個(gè)新窗口</a>
這是符合strict標(biāo)準(zhǔn)的方法。當(dāng)然還必須配合一個(gè)javascript才有效。
javascript
完整的代碼JS如下:
示例代碼 [hl5o.cn]
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;
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;
你可以把它保存成一個(gè).js文件(比如external.js),然后通過外部聯(lián)接方法調(diào)用:
示例代碼 [hl5o.cn]
<script type="text/javascript" src="external.js"></script>
最后補(bǔ)充,標(biāo)簽target="new"在過渡型DOCTYPE下是允許的,但也不符合strict標(biāo)準(zhǔn)。
將所有target="new"改成rel="external"則是完全符合標(biāo)準(zhǔn)的標(biāo)簽!
本文參考了以下文章:Kevin Yank的《New-Window Links in a Standards-Compliant World》
《Standards-based Replacement for target="_blank" in External Links》
相關(guān)XHTML教程:
- HTML5 INPUT placeholder及兼容性處理
- HTML表單里的Label標(biāo)簽
- 淺析HTML與javascript中常用編碼
- CSS網(wǎng)頁布局中必須要了解的幾個(gè)XHTML標(biāo)簽
- title和alt 標(biāo)簽介紹及其異同
- 淺析HTML標(biāo)簽strong和em的區(qū)別
- 說說XHTML中的alt屬性和title屬性
- Semantics語義是Html Xhtml是否真正符合標(biāo)準(zhǔn)的重要部分
- 九個(gè)W3C XHTML1.0及CSS標(biāo)準(zhǔn)認(rèn)證需要注意的問題
- 請注意頁面head區(qū)域的編碼是不是規(guī)范
- HTML validate - 驗(yàn)證HTML代碼穿越多重瀏覽器標(biāo)準(zhǔn)
- XHTML具有語義的標(biāo)簽:有關(guān)H1位置的討論
- 相關(guān)鏈接:
- 教程說明:
XHTML教程-不符合web標(biāo)準(zhǔn)的target="_blank"標(biāo)簽
。