a href=#與a href=javascript:void(0) 的區別

來源:互聯網
上載者:User

之前在專案,用到超連結,在ie下沒有問題,但是到了ie6,居然發現點擊事件不起作用,#FormatImgID_0# 真不可思議,以前都沒注意到,後來網上搜了下,問題就出在這個void(0)上!現把網上的資料整理了下。

Html代碼 #FormatImgID_1#<ahref=」javaScript:void(0)」 onClick=」doSomething();」 >doSomethind</a>


讓我們先來看看JavaScript中void(0)的含義:
JavaScript中void是一個操作符,該操作符指定要計算一個運算式但是不傳回值。

void 操作符用法格式如下:

Html代碼 #FormatImgID_2#javascript:void (expression) javascript:void expression


expression是一個要計算的 JavaScript 標準的運算式。 運算式外側的圓括弧是可選的,但是寫上去是一個好習慣。 我們可以使用 void 操作符指定超級連結。 運算式會被計算但是不會在當前文檔處裝入任何內容。 面的代碼創建了一個超級連結,當使用者點擊以後不會發生任何事。 當使用者點選連結時,void(0) 計算為 0,但在 JavaScript 上沒有任何效果。

Html代碼 #FormatImgID_3#<ahref=」javascript:void(0)」>按一下此處什麼也不會發生</a>


也就是說,要執行某些處理,但是不整體刷新頁面的情況下,可以使用void(0),但是在需要對頁面進行refresh的情況下,那就要仔細了。

Html代碼 #FormatImgID_4#<ahref=」javascript:void(document.form.submit())」>


其實我們可以用上面的代碼,這句話會進行一次submit操作。 那什麼情況下用void(0)比較多呢,無刷新,當然是Ajax了,看一下 Ajax的web頁面的話,一般都會看到有很多的void(0),:D 所以在使用void(0)之前,最好先想一想,這個頁面是否需要整體刷新。

Html代碼 #FormatImgID_5#<scripttype="text/javascript"> function goUrl(x){ window.location.href=x; } </ script><ahref="javascript:;" onclick="javascript:goUrl('HTTP://www.sina.com');" >跳轉1</a><ahref="javascript:void(0);" onclick="javascript:goUrl('HTTP://www.sina.com');" >跳轉2</a><ahref="javascript:void(0);" onclick="javascript:goUrl('HTTP://www.sina.com');return false;" >跳轉3</a><ahref="#"onclick="javascript:goUrl('HTTP://www.sina.com');" >跳轉4</a><ahref="###"onclick="javascript:goUrl('HTTP://www.sina.com');" >跳轉5</a>


測試環境IE6,IE7,Firefox 3。

跳轉1和2在IE6環境下無效,3、4、5在IE6,IE7,Firefox3.01下測試均能 通過,。

跳轉4和5最簡潔。

關鍵在於<a>的href屬性,空連結用"#","###"。

為了不返回網頁頂端。

空連結推薦用"###"。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.