網(wǎng)頁(yè)打開(kāi)新窗口target=_blank不符合標(biāo)準(zhǔn)
更新時(shí)間:2008年05月16日 22:17:35 作者:
我們要在新窗口中打開(kāi)鏈接通常的做法是在鏈接后面加target="_blank",我們采用過(guò)渡型的DOCTYPE(xh
tml1-transitional. dtd)時(shí)沒(méi)有問(wèn)題,但是當(dāng)我們使用嚴(yán)格的DOCTYPE(xhtml1-strict.dtd)時(shí),這個(gè)方法將通不過(guò)W3C的校驗(yàn),會(huì)出現(xiàn)如下錯(cuò)誤提示:
"there is no attribute target for this element(in this HTML version)"
原來(lái)在HTML4.01/XHTML1.0/XHTML1.1嚴(yán)格DOCTYPE下,target="_blank"、target="_self"等等語(yǔ)法都是無(wú)效的,我們只能通過(guò)JavaScript來(lái)變通實(shí)現(xiàn)。
有朋友問(wèn)為什么不允許使用target="_blank"?這個(gè)屬性很方便啊。呵呵,不知道W3C的專家們是怎么想的,據(jù)我所知,主要是“易用性、友好性”的問(wèn)題,因?yàn)槔贤庥X(jué)得不經(jīng)過(guò)用戶同意,沒(méi)有明確提示就打開(kāi)一個(gè)新窗口是不禮貌的。先不管這個(gè)取消是否合理,我們來(lái)看看解決辦法。
rel屬性
HTML4.0增加了一個(gè)新屬性:rel,這個(gè)屬性用來(lái)說(shuō)明鏈接和包含此鏈接頁(yè)面的關(guān)系,以及鏈接打開(kāi)的目標(biāo)。rel有許多的屬性值,比如next、previous、chapter、section等等。我們要使用的就是rel="external"屬性。原來(lái)這樣寫(xiě)的代碼:
<a href="document.html" target="_blank">
打開(kāi)一個(gè)新窗口</a>
現(xiàn)在要寫(xiě)成這樣:<a href="document.html" rel="external">打開(kāi)一個(gè)新窗口</a>
這是符合strict標(biāo)準(zhǔn)的方法。當(dāng)然還必須配合一個(gè)javascript才有效。
javascript
完整的代碼JS如下:
function externallinks() {
if (!document.getElementsByTagName) return;
var anchors = document.getElementsByTagName("a");
for (var i=0; i<anchors.length; i++) {
var anchor = anchors[i];
if (anchor.getAttribute("href") &&
anchor.getAttribute("rel") == "external")
anchor.target = "_blank";
}
}
window.onload = externallinks;
你可以把它保存成一個(gè).js文件(比如external.js),然后通過(guò)外部聯(lián)接方法調(diào)用:<script type="text/javascript" src="external.js"></script>
就是這樣。
最后補(bǔ)充一句,我網(wǎng)站采用的target="new"在過(guò)渡型DOCTYPE下是允許的,但也不符合strict標(biāo)準(zhǔn)。下次改版時(shí)我將采用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更新
很多門戶網(wǎng)站的首頁(yè)全部是彈出式的,我估計(jì)至少在中國(guó)這種觀念暫時(shí)還改不了,在這種情況下就不需要在每個(gè)鏈接下加rel,全代碼如下:
<script type="text/javascript">//<![CDATA[
function externalLinks() {
if (!document.getElementsByTagName) return;
var anchors = document.getElementsByTagName("a");
for (var i=0; i<anchors.length; i++){
var anchor = anchors;
if (anchor.getAttribute("href"))
anchor.target ="_blank";
}
}
window.onload = externalLinks;
//]]></script>
原來(lái)在HTML4.01/XHTML1.0/XHTML1.1嚴(yán)格DOCTYPE下,target="_blank"、target="_self"等等語(yǔ)法都是無(wú)效的,我們只能通過(guò)JavaScript來(lái)變通實(shí)現(xiàn)。
有朋友問(wèn)為什么不允許使用target="_blank"?這個(gè)屬性很方便啊。呵呵,不知道W3C的專家們是怎么想的,據(jù)我所知,主要是“易用性、友好性”的問(wèn)題,因?yàn)槔贤庥X(jué)得不經(jīng)過(guò)用戶同意,沒(méi)有明確提示就打開(kāi)一個(gè)新窗口是不禮貌的。先不管這個(gè)取消是否合理,我們來(lái)看看解決辦法。
rel屬性
HTML4.0增加了一個(gè)新屬性:rel,這個(gè)屬性用來(lái)說(shuō)明鏈接和包含此鏈接頁(yè)面的關(guān)系,以及鏈接打開(kāi)的目標(biāo)。rel有許多的屬性值,比如next、previous、chapter、section等等。我們要使用的就是rel="external"屬性。原來(lái)這樣寫(xiě)的代碼:
<a href="document.html" target="_blank">
打開(kāi)一個(gè)新窗口</a>
現(xiàn)在要寫(xiě)成這樣:<a href="document.html" rel="external">打開(kāi)一個(gè)新窗口</a>
這是符合strict標(biāo)準(zhǔn)的方法。當(dāng)然還必須配合一個(gè)javascript才有效。
javascript
完整的代碼JS如下:
function externallinks() {
if (!document.getElementsByTagName) return;
var anchors = document.getElementsByTagName("a");
for (var i=0; i<anchors.length; i++) {
var anchor = anchors[i];
if (anchor.getAttribute("href") &&
anchor.getAttribute("rel") == "external")
anchor.target = "_blank";
}
}
window.onload = externallinks;
你可以把它保存成一個(gè).js文件(比如external.js),然后通過(guò)外部聯(lián)接方法調(diào)用:<script type="text/javascript" src="external.js"></script>
就是這樣。
最后補(bǔ)充一句,我網(wǎng)站采用的target="new"在過(guò)渡型DOCTYPE下是允許的,但也不符合strict標(biāo)準(zhǔn)。下次改版時(shí)我將采用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更新
很多門戶網(wǎng)站的首頁(yè)全部是彈出式的,我估計(jì)至少在中國(guó)這種觀念暫時(shí)還改不了,在這種情況下就不需要在每個(gè)鏈接下加rel,全代碼如下:
<script type="text/javascript">//<![CDATA[
function externalLinks() {
if (!document.getElementsByTagName) return;
var anchors = document.getElementsByTagName("a");
for (var i=0; i<anchors.length; i++){
var anchor = anchors;
if (anchor.getAttribute("href"))
anchor.target ="_blank";
}
}
window.onload = externalLinks;
//]]></script>
相關(guān)文章
CSS expression控制圖片自動(dòng)縮放效果代碼[兼容 IE,Firefox]
一直以來(lái)有個(gè)很頭疼的問(wèn)題困擾著我,那就是圖片縮放的問(wèn)題,寫(xiě)到 JS 里面吧,不太容易修改。寫(xiě)到 CSS 里面吧,IE 6 又不支持 max-width2008-09-09
[轉(zhuǎn)]Accesskey引起的一點(diǎn)點(diǎn)思考
[轉(zhuǎn)]Accesskey引起的一點(diǎn)點(diǎn)思考...2007-02-02
網(wǎng)頁(yè)布局設(shè)計(jì)的標(biāo)準(zhǔn)尺寸
許多的網(wǎng)頁(yè)設(shè)計(jì)在進(jìn)行網(wǎng)頁(yè)布局設(shè)計(jì)時(shí),進(jìn)行界面網(wǎng)頁(yè)的寬度尺寸設(shè)計(jì)都比較迷茫,800*600尺寸及1024*768尺寸的分辨率下,網(wǎng)頁(yè)應(yīng)該設(shè)計(jì)為多少像素才合適呢?太寬就會(huì)出現(xiàn)水平滾動(dòng)條了,下面我們就網(wǎng)頁(yè)設(shè)計(jì)的標(biāo)準(zhǔn)尺寸進(jìn)行講解.2008-03-03
用javascript來(lái)控制 鏈接的target 屬性的代碼
用javascript來(lái)控制 鏈接的target 屬性的代碼...2007-11-11
CSS Hack 匯總速查手冊(cè)瀏覽器兼容必會(huì)
為了兼容和區(qū)分多瀏覽器我們需要用一些css hack來(lái)解決這些問(wèn)題,但不建議用,能不用則不用2008-08-08
javascript橫排豎排標(biāo)準(zhǔn)選項(xiàng)卡效果代碼
嘿嘿,又搗鼓出一個(gè)選項(xiàng)卡來(lái)。以后就用這個(gè)了,很爽,無(wú)視Tab標(biāo)簽與容器的原始class值。 照樣結(jié)構(gòu)/樣式/行為分離~2008-05-05

