<a href="#"> 點擊鏈接後,頁面會向上滾到頁首,# 默認錨點爲 #TOP
<a href="javascript:void(0)" onClick="window.open()"> 點擊鏈接後,頁面不動,只打開鏈接
<a href="#" οnclick="javascript:return false;"> 作用同上,不同瀏覽器會有差異。
點擊鏈接後,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有類似作用
這就是爲什麼有的時候頁面很長瀏覽鏈接明明是#可是跳動到了頁首
而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)" οnclick="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="#" οnclick="return false"></a>
5:<span style="cursor:hand"></span>(好像在FF中不能顯示)
-------------------------------------------------------------------------------
慎用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="#" οnclick="javascript:方法">提交</a>的方式,通過一個僞鏈接來調用javascript方法.這種方法有一個問題是:
雖然點擊該鏈接的時候不會跳轉頁面.但是滾動條會往上滾,解決的辦法是返回一個false.
如下所示:
<a href="#" οnclick="javascript:方法;return false;">提交</a>
還可以用 ###
a href="javascript:void(0)" οnclick="javascript:方法;return false;"提交
javascript:void(0)就不會向上跳了:)