javascript:void(0)的問題

原文轉載自:http://www.cnblogs.com/chu888chu888/archive/2012/01/05/2313045.html

最近看了好幾個關於<a>和javascript:void(0)的帖子,謹記於此,以資查閱。

注:以下代碼未經全面測試,但每一種方法可能會出現的情況都基本做了說明。

 在做頁面時,如果想做一個鏈接點擊後不做任何事情,或者響應點擊而完成其他事情,可以設置其屬性 href = “#”,但是,這樣會有一個問題,就是當頁面有滾動條時,點擊後會返回到頁面頂端,用戶體驗不好。

目前有如下幾種解決辦法:
1)點擊鏈接後不做任何事情

1. <a href="javascript:void(0);" >test</a>

2. <a href="javascript:;" >test</a>

3. <a href="####" >test</a> //使用2個到4個#,見的大多是”####”,也有使用”#all”等其他的

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

1.  <a href="javascript:void(0)" onclick="doSomething()">test</a>

2. <a href="#" onclick="doSomething();return false;">

什麼問題都解決了,包括瀏覽器不兼容問題 //或者直接使用href=”"

3. <a href="#" onclick="alert();event.returnValue=false;">test</a>

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

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

void是javascript的操作符,意思是:只執行表達式,但沒有返回值,
void 操作符用法格式如下:
1. javascript:void (expression)
2. 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,所以會出現這種情況。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章