javascript:;與javascript:void(0)使用介紹


有時候我們在編寫js過程中,需要觸發事件而不需要返回值,那么就可能需要這樣的寫法。


注:以下代碼未經全面測試,但每一種方法可能會出現的情況都基本做了說明。 
在做頁面時,如果想做一個鏈接點擊后不做任何事情,或者響應點擊而完成其他事情,可以設置其屬性 href = "#",但是,這樣會有一個問題,就是當頁面有滾動條時,點擊后會返回到頁面頂端,用戶體驗不好。

目前有如下幾種解決辦法:

1)點擊鏈接后不做任何事情 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script src="jquery-1.11.1.min.js"></script>
</head>
<body>
<!--no click event-->
<div style="background-color: red;height: 700px">height</div>
<a href="javascript:void(0);">javascript:void(0);不含點擊事件</a>
<a href="javascript:;">javascript:;不含點擊事件</a>
<a href="####">#### 不含點擊事件</a>
<a>不含href及點擊事件</a>
<!--點擊事件-->
<a href="javascript:void(0);" onclick="test(this);">javascript:void(0);</a>
<a href="javascript:;" onclick="test(this);">javascript:;</a>
<a href="####" onclick="test(this);">test</a> //使用2個到4個#,見的大多是"####",也有使用"#all"等其他的
<script>
    function test(param) {
        var _href = $(param).attr("href") == undefined ? "" : $(param).attr("href");
        console.log("href is " + _href);
        window.location.href = _href;
    }
</script>
</body>
</html>

2)點擊鏈接后,響應用戶自定義的點擊事件

<a href="javascript:void(0)" onclick="doSomething()">test</a>
<a href="#" onclick="doSomething();return false;">什么問題都解決了,包括瀏覽器不兼容問題</a> //或者直接使用href="" 
<a href="#" onclick="alert();event.returnValue=false;">test</a>

說明:

1.javascript:void(0)這種偽協議,少寫的好,如果你看過一些web標准的書就知道為什么了。(不懂,原話摘的,暫做記錄) 
2.鏈接(href)直接使用javascript:void(0)在IE中可能會引起一些問題,比如:造成gif動畫停止播放等,所以,最安全的辦法還是使用“####”。為防止點擊鏈接后跳轉到頁首,onclick事件return false即可。 
3.如果僅僅是想鼠標移過,變成手形,可以使用

<span style="cursor:pointer" onclick="foo()">Click Me!</span>   

void是javascript的操作符,意思是:只執行表達式,但沒有返回值, 
void 操作符用法格式如下:

javascript:void (expression)  
javascript:void expression

為了程序風格良好,建議使用第二種帶上括號的。我們可以使用void操作符指定超級鏈接,如javascript:void(document.form.submit())。表達式會被計算但是不會在當前文檔處裝入任何內容,void(0)計算為0,但在JavaScript上沒有任何效果,也就是說 <a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是一樣的。關鍵是只要知道void是javascipt自身的操作符,它表示的是只執行表達式,但沒有返回值!另外頁面會自動調回頂端,是因為"#"默認的瞄點位置是top,所以會出現這種情況。 ​

繼續解釋

我想使用過ajax的都常見這樣的代碼:

<a href="javascript:doTest2();void(0);">here</a>

但這兒的void(0)究竟是何含義呢?Javascript中void是一個操作符,該操作符指定要計算一個表達式但是不返回值。

void 操作符用法格式如下:

1. javascript:void (expression)
2. javascript:void expression

expression 是一個要計算的 Javascript 標准的表達式。表達式外側的圓括號是選的,但是寫上去是一個好習慣。 (實現版本   Navigator 3.0   )你以使用 void 操作符指定超級鏈接。表達式會被計算但是不會當前文檔處裝入任何內容。下面的代碼創建了一個超級鏈接,當用戶以后不會發生任何事。當用戶鏈接時,void(0) 計算為 0,但 Javascript 上沒有任何效果。

<a href="javascript:void(0)">單此處什么也不會發生</a>

下面的代碼創建了一個超級鏈接,用戶單時會提交表單。

<a href="javascript:void(document.form.submit())">單此處提交表單</a>

a href=#與 a href=javascript:void(0) 的區別鏈接的幾種辦法

#包含了一個位置信息,默認的錨是#top 也就是網頁的上端,而javascript:void(0)僅僅表示一個死鏈接,這就是為什么有的時候頁面很長瀏覽鏈接明明是#卻跳動到了頁首。而javascript:void(0) 則不是如此,所以調用腳本的時候最好用void(0)或者<input onclick>或<div onclick>等

鏈接的幾種辦法
1.window.open(''url'')

2.用自定義函數

<script>
function openWin(tag,obj)
 {
  obj.target="_blank";
  obj.href = "Web/Substation/Substation.aspx?stationno="+tag;
  obj.click();
  }
</script>

<a href="javascript:void(0)" onclick="openWin(3,this)">株洲</a>

window.location.href=""

href=”#”,包含了一個位置信息.默認的錨是#top,也就是網頁的上端,當連續快速點擊此鏈接時會導致瀏覽器巨慢甚至崩潰。當然我們一般用三個 href="###",不過看了這篇文章我們以后就可以使用javascript:;(一個冒號一個分號)。
javascript中void是一個操作符,該操作符指定要計算一個表達式但是不返回值。 
javascript:;好些,javascript:void(0);據說某些情況下有瀏覽器兼容bug。(此點bug我也不知道什么時候能出現,知道的童鞋請指教)。 
可以寫成javascript:;,qq空間很多都是寫成javascript:; 
我感覺這兩者之間沒有什么差別,都是執行一個空事件。 
javascript:;甚至少了7個字符,呵呵。 
新浪微博寫的是javascript:void(0); 
我以前一直寫的是javascript:void(0);但是現在寫的都是javascript:;

a href="#"> 點擊鏈接后,頁面會向上滾到頁首,# 默認錨點為 #TOP
<a href="javascript:void(0)" onClick="window.open()"> 點擊鏈接后,頁面不動,只打開鏈接
<a href="#" onclick="javascript:return false;"> 作用同上,不同瀏覽器會有差異。

點擊鏈接后,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有類似作用

詳解href="#"與href="javascript:void(0)"的區別

"#"包含了一個位置信息
默認的錨點是#top 也就是網頁的上端
而javascript:void(0) 僅僅表示一個死鏈接
這就是為什么有的時候頁面很長瀏覽鏈接明明是#可是跳動到了頁首
而javascript:void(0) 則不是如此
所以調用腳本的時候最好用void(0)
或者<input onclick>
<div onclick>等
打開新窗口鏈接的幾種辦法
1.window.open('url')
2.用自定義函數

 

復制代碼代碼如下:

        <script>
        function openWin(tag,obj)
        {
            obj.target="_blank";
            obj.href = "Web/Substation/Substation.aspx?stationno="+tag;
            obj.click();
        }
        </script>
<a href="javascript:void(0)" onclick="openWin(3,this)">LINK_TEST</a>

 

window.location.href=""

如果是個# ,就會出現跳到頂部的情況,個人收藏的幾種解決方法:
1:<a href="####"></a>
2:<a href="javascript:void(0)"></a>
3:<a href="javascript:void(null)"></a>
4:<a href="#" onclick="return false"></a>
5:<span style="cursor:hand"></span>(好像在FF中不能顯示)


慎用JavaScript:void(0)
今天調試CGI的時候,明明CGI程序已經執行,並且最后結果也是正確的,但是頁面就是不刷新。在FireFox2.0下測試,結果卻是正常的,IE6卻偏偏不刷新!仔細調查了一下,發現cgi頁面鏈接的是 <a href="javaScript:void(0)" OnClick="XXX_Func();" ….> only a sample </a>,問題就出在這個void(0)上!讓我們先來看看JavaScript中void(0)的含義:
JavaScript中void是一個操作符,該操作符指定要計算一個表達式但是不返回值。
void 操作符用法格式如下:
1. javascript:void (expression_r_r)
2. javascript:void expression_r_r
expression_r_r是一個要計算的 JavaScript 標准的表達式。表達式外側的圓括號是可選的,但是寫上去是一個好習慣。我們可以使用 void 操作符指定超級鏈接。表達式會被計算但是不會在當前文檔處裝入任何內容。面的代碼創建了一個超級鏈接,當用戶點擊以后不會發生任何事。當用戶點擊鏈接時,void(0) 計算為 0,但在 JavaScript 上沒有任何效果。
<a href="javascript:void(0)">單擊此處什么也不會發生</a>
也就是說,要執行某些處理,但是不整體刷新頁面的情況下,可以使用void(0),但是在需要對頁面進行refresh的情況下,那就要仔細了。
其實我們可以這樣用<a href="javascript:void(document.form.submit())">,這句話會進行一次submit操作。那什么情況下用void(0)比較多呢,無刷新,當然是Ajax了,看一下Ajax的web頁面的話,一般都會看到有很多的void(0),:) ,所以在使用void(0)之前,最好先想一想,這個頁面是否需要整體刷新。

使用javascript的時候,通常我們會通過類似:<a href="#" onclick="javascript:方法">提交</a>的方式,通過一個偽鏈接來調用javascript方法.這種方法有一個問題是:雖然點擊該鏈接的時候不會跳轉頁面.但是滾動條會往上滾,解決的辦法是返回一個false。
如下所示:<a href="#" onclick="javascript:方法;return false;">提交</a>

還可以用 ###

a href="javascript:void(0)" onclick="javascript:方法;return false;"提交
javascript:void(0)就不會向上跳了:)

還有一個方法是 #this
a href="#this" onclick="javascript:方法"


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM