javascript
javascript:void(0)和javascript:;的用法
一、JavaScript:void(0)
我們經(jīng)常會使用到 javascript:void(0) 這樣的代碼,那么在 JavaScript 中 javascript:void(0) 代表的是什么意思呢?
javascript:void(0) 中最關(guān)鍵的是 void 關(guān)鍵字, void 是 JavaScript 中非常重要的關(guān)鍵字,該操作符指定要計算一個表達式但是不返回值。
JavaScript中void是一個操作符,該操作符指定要計算一個表達式但是不返回值。
void?操作符用法格式如下:
1. javascript:void (expression)
2. javascript:void expression
expression是一個要計算的?JavaScript?標(biāo)準的表達式。表達式外側(cè)的圓括號是可選的,但是寫上去是一個好習(xí)慣。
我們可以使用void?操作符指定超級鏈接。表達式會被計算但是不會在當(dāng)前文檔處裝入任何內(nèi)容。
下面的代碼創(chuàng)建了一個超級鏈接,當(dāng)用戶點擊以后不會發(fā)生任何事。當(dāng)用戶點擊鏈接時,void(0)?計算為?0,但在?JavaScript?上沒有任何效果。
<a href="javascript:void(0)">單擊此處什么也不會發(fā)生</a>也就是說,要執(zhí)行某些處理,但是不整體刷新頁面的情況下,可以使用void(0),但是在需要對頁面進行refresh的情況下,那就要仔細了。
下面的代碼創(chuàng)建了一個超級鏈接,用戶單擊時會提交表單。
<a href="javascript:void(document.form.submit())">單此處提交表單</a>其實我們可以這樣用<a href="javascript:void(document.form.submit())">,這句話會進行一次submit操作。那什么情況下用void(0)比較多呢,無刷新,當(dāng)然是Ajax了,看一下Ajax的web頁面的話,一般都會看到有很多的void(0),所以在使用void(0)之前,最好先想一想,這個頁面是否需要整體刷新。
二、<a>標(biāo)簽中href="javascript:;"
<a> 標(biāo)簽的 href 屬性用于指定超鏈接目標(biāo)的 URL,href 屬性的值可以是任何有效文檔的相對或絕對 URL,包括片段標(biāo)識符和 JavaScript 代碼段。這里的href="javascript:;",其中javascript:是偽協(xié)議,它可以讓我們通過一個鏈接來調(diào)用javascript函數(shù).而采用這個方式 javascript:;可以實現(xiàn)A標(biāo)簽的點擊事件運行時,如果頁面內(nèi)容很多,有滾動條時,頁面不會亂跳,用戶體驗更好。 javascript:是表示在觸發(fā)<a>默認動作時,執(zhí)行一段JavaScript代碼,而?javascript:; 表示什么都不執(zhí)行,這樣點擊<a>時就沒有任何反應(yīng)。 javascript:;表示這是一個空連接。點擊之后沒任何反應(yīng)。
類似的是#,但是一個#點擊之后頁面很長的情況下會會滾到頂部;而javascript:;沒這樣的問題;
當(dāng)然###這樣的效果就跟javascript:;一樣了
三、href="#"與href="javascript:void(0)"的區(qū)別
#?包含了一個位置信息,默認的錨是#top?也就是網(wǎng)頁的上端。
而javascript:void(0), 僅僅表示一個死鏈接。
在頁面很長的時候會使用?#?來定位頁面的具體位置,格式為:# + id。
如果你要定義一個死鏈接請使用 javascript:void(0) 。
在做頁面時,如果想做一個鏈接點擊后不做任何事情,或者響應(yīng)點擊而完成其他事情,可以設(shè)置其屬性 href = "#",但是,這樣會有一個問題,就是當(dāng)頁面有滾動條時,點擊后會返回到頁面頂端,用戶體驗不好。?
目前有如下幾種解決辦法:?
1)點擊鏈接后不做任何事情?
2)點擊鏈接后,響應(yīng)用戶自定義的點擊事件?
說明:?
1.javascript:void(0)這種偽協(xié)議,少寫的好,如果你看過一些web標(biāo)準的書就知道為什么了。(不懂,原話摘的,暫做記錄)?
2.鏈接(href)直接使用javascript:void(0)在IE中可能會引起一些問題,比如:造成gif動畫停止播放等,所以,最安全的辦法還是使用“####”。為防止點擊鏈接后跳轉(zhuǎn)到頁首,onclick事件return false即可。?
3.如果僅僅是想鼠標(biāo)移過,變成手形,可以使用?
?
void是javascript的操作符,意思是:只執(zhí)行表達式,但沒有返回值,?
void 操作符用法格式如下:?
為了程序風(fēng)格良好,建議使用第二種帶上括號的?
我們可以使用void操作符指定超級鏈接,如javascript:void(document.form.submit())。表達式會被計算但是不會在當(dāng)前文檔處裝入任何內(nèi)容,void(0)計算為0,但在JavaScript上沒有任何效果,也就是說 <a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是一樣的。?
關(guān)鍵是只要知道void是javascipt自身的操作符,它表示的是只執(zhí)行表達式,但沒有返回值!?
另外頁面會自動調(diào)回頂端,是因為"#"默認的瞄點位置是top,所以會出現(xiàn)這種情況。
轉(zhuǎn)載于:https://www.cnblogs.com/Qian123/p/5345697.html
總結(jié)
以上是生活随笔為你收集整理的javascript:void(0)和javascript:;的用法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Core Spring】二、装配bea
- 下一篇: iOS UICollectionView