国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > WEB開發(fā) > 正文

target=_網(wǎng)站重構(gòu)教程

2024-04-27 13:53:36
字體:
供稿:網(wǎng)友
本文參考了以下文章:

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)時沒有問題,但是當(dāng)我們使用嚴(yán)格的DOCTYPE(xhtml1-strict.dtd)時,這個方法將通不過W3C的校驗,會出現(xiàn)如下錯誤提示:

"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來變通實現(xiàn)。

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

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

<a href="document.html" target="_blank">打開一個新窗口</a>
現(xiàn)在要寫成這樣:

<a href="document.html" rel="external">打開一個新窗口</a>
這是符合strict標(biāo)準(zhǔn)的方法。當(dāng)然還必須配合一個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),然后通過外部聯(lián)接方法調(diào)用:

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

最后補充一句,我網(wǎng)站采用的target="new"在過渡型DOCTYPE下是答應(yīng)的,但也不符合strict標(biāo)準(zhǔn)。下次改版時我將采用strict模式,將所有target="new"改成rel="external"。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 固安县| 鹿邑县| 福安市| 白山市| 施秉县| 崇仁县| 桃江县| 新余市| 佛山市| 开封县| 政和县| 揭阳市| 高安市| 行唐县| 千阳县| 武宣县| 胶南市| 台湾省| 略阳县| 阳谷县| 丰城市| 会东县| 东乡县| 肇庆市| 肃北| 上饶市| 万年县| 梨树县| 旺苍县| 淳化县| 夏邑县| 会昌县| 柏乡县| 青河县| 平昌县| 前郭尔| 依兰县| 北海市| 平邑县| 新化县| 德兴市|