合肥市高新區(qū)長(zhǎng)江西路與科學(xué)大道交口5F創(chuàng)業(yè)園A座309
136 5560 1775

rel=external和target=_blank區(qū)別 誰(shuí)符合W3C標(biāo)準(zhǔn)?

發(fā)表日期:2011-04-16 瀏覽次數(shù):3299次

rel=external和target=_blank區(qū)別 誰(shuí)符合W3C標(biāo)準(zhǔn)?
target,允許指定在什么位置顯示已經(jīng)選擇的超鏈接內(nèi)容。也就是說(shuō)鏈接的內(nèi)容將在什么樣的窗口被顯示。target 的屬性值有四個(gè)保留的名稱,分別是:_blank,_self,_parent,_top。其中_blank的意思是瀏覽器總在一個(gè)新打開(kāi)的、未命名的窗口中載入target="_blank"鏈接的文檔。這里大家也許會(huì)很不理解“未命名”是什么意思。事實(shí)上target 是可以給新打開(kāi)的窗口賦一個(gè)ID,例如:target="name" 這就表明通過(guò)target="name"鏈接載入的文檔將會(huì)在一個(gè)叫"name"的窗口顯示。如果沒(méi)有ID為"name"的窗口,那么瀏覽器就會(huì)新建一個(gè)名為"name"的窗口來(lái)顯示鏈接文檔。如果當(dāng)前窗口的ID就是"name"那么這個(gè)鏈接文檔就會(huì)在當(dāng)前的窗口中替換原有的內(nèi)容顯示出來(lái)。而_self的意思其實(shí)就是當(dāng)前文檔,<a>的默認(rèn)目標(biāo)就是_self,這個(gè)屬性值一般來(lái)說(shuō)是用不到的。_parent是使鏈接文檔在父級(jí)窗口顯示,這個(gè)屬性值只在框架結(jié)構(gòu)中使用,如果身本就是頂級(jí)框架,那么其作用與_self相同。_top同樣是應(yīng)用在框架中的,但是他的效果是清除框架來(lái)顯示目標(biāo)文檔。這對(duì)于從框架結(jié)構(gòu)轉(zhuǎn)向無(wú)框架結(jié)構(gòu)是很有作用的。

現(xiàn)在我們知道了,target 是一目標(biāo)顯示的屬性與瀏覽器密切相關(guān)的。那么rel又是什么呢, 為什么很多人把他當(dāng)作是target 的替代屬性呢?下面網(wǎng)站建設(shè)就來(lái)認(rèn)識(shí)一下rel。

 

我們要在新窗口中打開(kāi)鏈接通常的做法是在鏈接后面加target="_blank",我們采用過(guò)渡型的DOCTYPE(xhtml1-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="http://rlfp.cn" target="_blank">打開(kāi)一個(gè)新窗口</a> 現(xiàn)在要寫(xiě)成這樣:
<a 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;
if (anchor.getAttribute("href") &&
anchor.getAttribute("rel") == "external")
anchor.target = "_blank";
}
}
window.onload = externalLinks;
你可以把它保存成一個(gè).js文件(比如blank.js),然后通過(guò)外部聯(lián)接方法調(diào)用:
<script type="text/javascript" src="blank.js"></script>


將文章分享到:

版權(quán)所有:?jiǎn)⑦~科技-合肥網(wǎng)站建設(shè) 皖I(lǐng)CP備19009304號(hào)-1 皖公網(wǎng)安備 34010402702162號(hào)

網(wǎng)站建設(shè),網(wǎng)站設(shè)計(jì)公司啟邁科技,為眾多企業(yè)提供網(wǎng)站建設(shè),網(wǎng)站制作,響應(yīng)式網(wǎng)站設(shè)計(jì),手機(jī)網(wǎng)站建設(shè),微網(wǎng)站,模板建站,企業(yè)郵箱等一站式互聯(lián)網(wǎng)解決方案和建站服務(wù)10年。