首頁  >  文章  >  web前端  >  詳解a href=#與 a href=javascript:void(0) 的差異_HTML/Xhtml_網頁製作

詳解a href=#與 a href=javascript:void(0) 的差異_HTML/Xhtml_網頁製作

WBOY
WBOY原創
2016-05-16 16:37:141282瀏覽

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

點選連結後,頁面不動,只開啟連結

作用同上,不同瀏覽器會有差異。

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

詳解href="#"與href="javascript:void(0)"的區別

"#"包含了一個位置資訊
預設的錨點是#top 也就是網頁的上端
而javascript:void(0) 僅僅表示一個死連結
這就是為什麼有的時候頁面很長瀏覽連結明明是#可是跳動到了頁首
而) 則不是如此
所以呼叫腳本的時候最好用void(0)



開啟新視窗連結的幾種方法

1.window.open('url')
2.用自定義函數

複製代碼
程式碼如下:

window.location.href=""
------------------------------------ -------------------------------------------
如果是個# ,就會出現一個跳到頂端的情況,個人收藏的幾種解決方法:
1:
2:
3:
4:
5:(好像在FF中不能顯示)
---------------- -------------------------------------------------- -------------
慎用JavaScript:void(0)

今天調試CGI的時候,明明CGI程式已經執行,並且最後結果也是正確的,但是頁面就是不刷新。在FireFox2.0下測試,結果卻是正常的,但IE6卻偏偏不刷新!仔細調查了一下,發現cgi頁面連結的是 only a sample ,問題就出在這個void(0 )上!讓我們先來看看JavaScript中void(0)的意思:
JavaScript中void是一個操作符,該操作符指定要計算一個表達式但是不傳回值。

void 運算子用法格式如下:

1. javascript:void (expression_r_r)
2. javascript:void expression_r_r
點擊此處什麼也不會發生
也就是說,要執行某些處理,但是不整體刷新頁面的情況下,可以使用void(0),但是在需要對頁面進行refresh的情況下,那就要仔細了。
其實我們可以這樣用,這句話會進行一次submit運算。那什麼情況下用void(0)比較多呢,無刷新,當然是Ajax了,看一下Ajax的web頁面的話,通常都會看到有很多的void(0),:) ,所以在使用void(0 )之前,最好先想想,這個頁面是否需要整體刷新。

使用javascript的時候,通常我們會通過類似:

提交
的方式,通過一個偽連結來呼叫javascript方法.這種方法有一個問題是:
雖然點擊該連結的時候不會跳轉頁面.但是滾動條會往上滾,解決的辦法是返回一個false.

如下:

提交

還可以用###

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

還有一個方法是#this

a href="#this" onclick="javascript:方法"

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn