咱們常常會使用到 javascript:void(0) 這樣的代碼,那麼在 JavaScript 中 javascript:void(0) 表明的是什麼意思呢?javascript
javascript:void(0) 中最關鍵的是 void 關鍵字, void 是 JavaScript 中很是重要的關鍵字,該操做符指定要計算一個表達式可是不返回值。java
JavaScript中void是一個操做符,該操做符指定要計算一個表達式可是不返回值。
void 操做符用法格式以下:
1. javascript:void (expression)
2. javascript:void expressionweb
expression是一個要計算的 JavaScript 標準的表達式。表達式外側的圓括號是可選的,可是寫上去是一個好習慣。express
咱們可使用void 操做符指定超級連接。表達式會被計算可是不會在當前文檔處裝入任何內容。瀏覽器
下面的代碼建立了一個超級連接,當用戶點擊之後不會發生任何事。當用戶點擊連接時,void(0) 計算爲 0,但在 JavaScript 上沒有任何效果。安全
<a href="javascript:void(0)">單擊此處什麼也不會發生</a>
也就是說,要執行某些處理,可是不總體刷新頁面的狀況下,可使用void(0),可是在須要對頁面進行refresh的狀況下,那就要仔細了。函數
下面的代碼建立了一個超級連接,用戶單擊時會提交表單。動畫
<a href="javascript:void(document.form.submit())">單此處提交表單</a>
其實咱們能夠這樣用<a href="javascript:void(document.form.submit())">,這句話會進行一次submit操做。那什麼狀況下用void(0)比較多呢,無刷新,固然是Ajax了,看一下Ajax的web頁面的話,通常都會看到有不少的void(0),因此在使用void(0)以前,最好先想想,這個頁面是否須要總體刷新。spa
# 包含了一個位置信息,默認的錨是#top 也就是網頁的上端。code
而javascript:void(0), 僅僅表示一個死連接。
在頁面很長的時候會使用 # 來定位頁面的具體位置,格式爲:# + id。
若是你要定義一個死連接請使用 javascript:void(0) 。
在作頁面時,若是想作一個連接點擊後不作任何事情,或者響應點擊而完成其餘事情,能夠設置其屬性 href = "#",可是,這樣會有一個問題,就是當頁面有滾動條時,點擊後會返回到頁面頂端,用戶體驗很差。
目前有以下幾種解決辦法:
1)點擊連接後不作任何事情
2)點擊連接後,響應用戶自定義的點擊事件
說明:
1.javascript:void(0)這種僞協議,少寫的好,若是你看過一些web標準的書就知道爲何了。(不懂,原話摘的,暫作記錄)
2.連接(href)直接使用javascript:void(0)在IE中可能會引發一些問題,好比:形成gif動畫中止播放等,因此,最安全的辦法仍是使用「####」。爲防止點擊連接後跳轉到頁首,onclick事件return false便可。
3.若是僅僅是想鼠標移過,變成手形,可使用
void是javascript的操做符,意思是:只執行表達式,但沒有返回值,
void 操做符用法格式以下:
爲了程序風格良好,建議使用第二種帶上括號的 咱們可使用void操做符指定超級連接,如javascript:void(document.form.submit())。表達式會被計算可是不會在當前文檔處裝入任何內容,void(0)計算爲0,但在JavaScript上沒有任何效果,也就是說 <a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是同樣的。 關鍵是隻要知道void是javascipt自身的操做符,它表示的是隻執行表達式,但沒有返回值! 另外頁面會自動調回頂端,是由於"#"默認的瞄點位置是top,因此會出現這種狀況。