IE6下javascript:void(0)的詭異與解決辦法


IE6下<a href="#">與<a href="javascript:void(0);">的區別 

JavaScript AjaxIEFirefoxHTML.

之前在項目,用到超鏈接,在ie6+下沒有問題,但是到了ie6,居然發現點擊事件不起作用, 真不可思議,以前都沒注意到,后來網上搜了下,問題就出在這個void(0)上!現把網上的資料整理了下。 

 

Html代碼  <a href=”javaScript:void(0)” onClick=”doSomething();”>doSomethind</a>  

 

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

void 操作符用法格式如下: 

Html代碼  
1. javascript:void (expression)   
2. javascript:void expression  
3. javascript:void (expression)
4. javascript:void expression

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

 

Html代碼  <a href=”javascript:void(0)”>單擊此處什么也不會發生</a>  

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

 

Html代碼  <a href=”javascript:void(document.form.submit())”>  

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

 


Html代碼   
<script type="text/javascript">   
    function goUrl(x){   
        window.location.href=x;   
    }   
</script>   

<a href="javascript:;" onclick="javascript:goUrl('http://www.sina.com');">跳轉1</a>
<a href="javascript:void(0);" onclick="javascript:goUrl('http://www.sina.com');">跳轉2</a>
<a href="javascript:void(0);" onclick="javascript:goUrl('http://www.sina.com');return false;">跳轉3</a>

<a href="#" onclick="javascript:goUrl('http://www.sina.com');">跳轉4</a>   

<a href="###" 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屬性,空鏈接用"#","###"。 

為了不返回網頁頂端。 

空鏈接推薦用"###"。 

 


免責聲明!

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



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