謹慎使用javascript:void(0),為什麼這樣寫不好
修正一個說法上的bug吧。對於IE6來說,點擊後gif暫停bug僅僅發生在「javascript:偽協議未加分號」的情形下
<a href="javascript:void(0)">
這樣寫為什麼不好?
我再來提供一個視角吧。
:link選擇器可以選擇到它
這個a標籤可以獲得焦點(可以透過tab按鍵存取)
在瀏覽器的預設樣式表中,有href屬性的標籤才有cursor:pointer的效果(尤其是在低版本的IE上)。
綁定了onclick事件的標籤,尤其是它的作用是ajax請求時,基本上我們就用不上這個標籤的預設行為,也連接不到的實際頁面,一般而言也會在CSS裡給予了這個元素的cursor等樣式。這時候還要加上href屬性,是為了:
讓夠響應鍵盤事件並獲得焦點(從而屏幕閱讀器能夠讀出背後的內容,增強可訪問性)
優雅降級,在網路連線很差,還沒載入到CSS的時候,依然有手型與正常的link樣式。
他們的體驗有細微的差別。
1,點擊這個連結後,會讓頁面跳到頭部,window.location.href末尾增加#(若window.location.href末尾沒有#),除非在js裡面捕獲onclick事件並阻止預設事件。
2有了初步的語意。但是,如果頁面裡面有id為nogo的元素,點擊這個連結後,錨點機制會作用,頁面貼齊這個元素上緣。更詳細的,詳見張鑫旭的《URL錨點HTML定位技術機制、應用與問題》
3在chrome中不再預設跳到頁面頭部,4在IE11中不再跳到頁面頭部。請參閱下方測試。
5~8作用相同,但使用了javascript偽協定。在IE6下面,未加分號的方案6和方案8被點擊後,IE6會使得頁面中的gif暫停,並且觸發onbeforeunload事件(詳情參考這裡),IE6認作這個頁面有了重定向,並abort之後所有的請求(參考這裡)。所以假如你在此之後取代了一個的src,IE6完全不會完成這個新的請求。
我比較傾向於使用方案4。
至於語意上LZ這種<a href="javascript:void(0)">使用方式,這裡已經有了足夠詳細的答案。我再補充一點,這種情形依然可以做到支援無障礙應用,方法請參考《WAI-ARIA無障礙網頁應用屬性》。
更新,我做瞭如下的測試:
<p> <a href="#">#</a> </p> <p> <a href="##">##</a> </p> <p> <a href="###">###</a> </p> <p> <a href="####">####</a> </p> <p> <a href="#####">#####</a> </p> <script type="text/javascript"> var n = 0 ; window.onhashchange = function(){ alert(++n) ; } </script>
在IE11中,點擊
、#和
##時,頁面不再跳到頭部在chrome中,點擊##、、
#和##時,頁面不再跳到頭部。
但在IE11和chrome中,點選所有的都會造成網址列的修改,並觸發hashchange事件。
所以之前說的「不會造成網址列的改變」是錯誤的。 沒有大規模測試其他的瀏覽器,這裡做初步猜想:的意義在於,這是字元數最少的,在所有的瀏覽器中不會導致跳到頁面頭部的錨點。
這麼寫沒什麼不好的,表明該部分的外觀像鏈接,滑鼠需要手型,需要響應點擊,但沒有實際動作。用來替代href="#"。這種寫法實質上並不算做html混雜js。
慎用void(0)
無論是用#還是void(0),有一個共同的缺點是:這樣做就讓這個行為,必須啟用js才能實作。別笑,雖然說大多數人是載入js的,但也不能排除連線故障等意外,或真的有少數狂人不用js。另外,js也不能被搜尋引擎所跟踪,這是一個需要考慮的問題。 從這個意義上講,#甚至更差一些,因為單獨的#在語義上,其實隱含著指向了網頁自己,如果使用「在新標籤頁中開啟」時就會產生迷惑。而這個問題void(0)沒有。 【相關推薦】
解決ie6下javascript:void(0) 無效的方法###############3. ###Javascript中的運算子void(0)的定義與詳解######4. 總結href=javascript:void(0)與href=#之間的差異
以上是謹慎使用javascript:void(0),為什麼這樣寫不好的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
