原來在HTML4.01/XHTML1.0/XHTML1.1嚴格DOCTYPE下,target="_blank"、target="_self"等等語法都是無效的,我們只能通過JavaScript來變通實現。 " /> 在线看片不卡,成人综合婷婷国产精品久久,中文av一区特黄

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

網頁打開新窗口target=_blank不符合標準

"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"屬性。原來這樣寫的代碼:

<a href="document.html" target="_blank">
打開一個新窗口</a>

現在要寫成這樣:<a href="document.html" rel="external">打開一個新窗口</a>

這是符合strict標準的方法。當然還必須配合一個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;

你可以把它保存成一個.js文件(比如external.js),然后通過外部聯接方法調用:<script type="text/Javascript" src="external.js"></script>

就是這樣。

最后補充一句,我網站采用的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,全代碼如下:

<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>

HTML/CSS技術網頁打開新窗口target=_blank不符合標準,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 寿阳县| 苏尼特左旗| 新野县| 汉川市| 婺源县| 即墨市| 贵港市| 沐川县| 东平县| 阿城市| 神木县| 涡阳县| 连山| 巨野县| 库车县| 本溪市| 湖口县| 鹿泉市| 绥化市| 安义县| 庐江县| 泰宁县| 墨玉县| 巴里| 鄂温| 墨江| 普兰县| 崇左市| 德兴市| 北票市| 武宣县| 霍林郭勒市| 益阳市| 霍林郭勒市| 米易县| 邮箱| 娱乐| 科技| 堆龙德庆县| 珲春市| 南乐县|