_blank開新視窗不符合標準?_CSS/HTML
本文參考了以下文章:
- Kevin Yank的《New-Window links in a Standards-Compliant World》
- 《Standards-based Replacement for target="_blank" in External links》
我們要在新視窗中開啟連結通常的做法是在連結後面加上target="_blank",我們採用過渡型的DOCTYPE(xh tml1-transitional. dtd)時沒有問題,但是當我們使用嚴格的DOCTYPE (xhtml1-strict.dtd)時,這個方法將通不過W3C的校驗,會出現以下錯誤提示:
"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="externa l"屬性。原來這樣寫的程式碼:
開啟一個新視窗現在要寫成這樣:
開啟一個新視窗這是符合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),然後透過外部聯結方法呼叫:
就是這樣。
最後補充一句,我網站採用的target="new"在過渡型DOCTYPE下是允許的,但也不符合strict標準。下次改版時我將採用strict模式,將所有target="new"改成rel="external"。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

CSS盒子陰影和輪廓屬性獲得了主題。讓我們查看一些在真實主題中起作用的示例,以及我們必須將這些樣式應用於WordPress塊和元素的選項。

Svelte Transition API提供了一種使組件輸入或離開文檔(包括自定義Svelte Transitions)時動畫組件的方法。

前幾天我只是和埃里克·邁耶(Eric Meyer)聊天,我想起了我成長時代的埃里克·邁耶(Eric Meyer)的故事。我寫了一篇有關CSS特異性的博客文章,以及
