a href=#與 a href=javascript:void(0) 的區別,以及location.href含義

來源:互聯網
上載者:User

1. location  :

 是windows視窗內的一個對像,它主要功能是從當前的網頁導向另外  
  一個網頁,href是它的一個屬性.通過它可以導向另外一個網頁同時也重新整理了此網頁.

 

2.

a href="#"> 點選連結後,頁面會向上滾到頁首,# 預設錨點為 #TOP

<a href="javascript:void(0)" onClick="window.open()"> 點選連結後,頁面不動,只開啟連結

<a href="#" onclick="javascript:return false;"> 作用同上,不同瀏覽器會有差異。

點選連結後,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有類似作用

 

"#"包含了一個位置資訊預設的錨點是#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 (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="#" onclick="javascript:方法">提交</a>
的方式,通過一個偽連結來調用javascript方法.這種方法有一個問題是:
雖然點擊該連結的時候不會跳轉頁面.但是捲軸會往上滾,解決的辦法是返回一個false.
如下所示:
<a href="#" onclick="javascript:方法;return false;">提交</a>

還可以用 ###

a href="javascript:void(0)" onclick="javascript:方法;return false;"提交
javascript:void(0)就不會向上跳了:)

還有一個方法是 #this
a href="#this" onclick="javascript:方法"

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.