1. 程式人生 > >關於A標籤使用onclick事件的疑問,若是href="#",跳轉無反應,以及href=#與href=javascript:void(0)的區別

關於A標籤使用onclick事件的疑問,若是href="#",跳轉無反應,以及href=#與href=javascript:void(0)的區別

#"包含了一個位置資訊

預設的錨點是#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)

JavaScript中void是一個操作符,該操作符指定要計算一個表示式但是不返回值。
void 操作符用法格式如下:
1. javascript:void (expression)
2. javascript:void expression
expression是一個要計算的 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)之前,最好先想一想,這個頁面是否需要整體重新整理。