IE6與a標籤使用void(0)的location.href失效問題[轉載]

爲什麼location.href不自動跳轉?慎用javascript:void(0)

<a href="javascript:void(0)" onclick="delete('123')">刪除</a>
<script>
function delete(id) {
if(confirm("確實要刪除[爲什麼location.href不自動跳轉?]嗎?")) {
location.href="/delete.jsp?id=" + id;
}
}
以上代碼不管如何檢查都沒有任何問題,而location.href="/delete.jsp?id=" + id;在別的地方都好使,爲什麼這段代碼就行呢?
原因是那個void(0),把代碼改成:
<a href="javascript:delete('123')">刪除</a>
<script>
function delete(id) {
if(confirm("確實要刪除[爲什麼location.href不自動跳轉?]嗎?")) {
location.href="/delete.jsp?id=" + id;
}
}
我們發現,頁面立即就跳轉了,能正常刪除相應的數據。

void是一個操作符,會計算一個表達式,但不會返回值,當然也不會改變當前頁面的任何內容,也就不會正常的跳轉。



"#"包含了一個位置信息默認的錨點是#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 (e­xpression)
2. javascript:void e­xpression
e­xpression 是一個要計算的 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)之前,最好先想一想,這個頁面是否需要整體刷新。----------------------------------
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章