標籤:ble file類 mit link ring 體驗 環境 自動裝箱拆箱 解決方案
有時候我們在編寫js過程中,需要觸發事件而不需要傳回值,那麼就可能需要這樣的寫法
最近看了好幾個關於<a>標籤和javascript:void(0)的文章,謹記於此,以資查閱。
註:以下代碼未經全面測試,但每一種方法可能會出現的情況都基本做了說明。
在做頁面時,如果想做一個連結點擊後不做任何事情,或者響應點擊而完成其他事情,可以設定其屬性 href = "#",但是,這樣會有一個問題,就是當頁面有捲軸時,點擊後會返回到頁面頂端,使用者體驗不好。
目前有如下幾種解決辦法:
1)點選連結後不做任何事情
?
123 |
<a href= "javascript:void(0);" >test</a> <a href= "javascript:;" >test</a> <a href= "####" >test</a> //使用2個到4個#,見的大多是"####",也有使用"#all"等其他的 |
2)點選連結後,響應使用者自訂的點擊事件
?
123 |
<a href= "javascript:void(0)" onclick= "doSomething()" >test</a> <a href= "#" onclick= "doSomething();return false;" >什麼問題都解決了,包括瀏覽器不相容問題</a> //或者直接使用href="" <a href= "#" onclick= "alert();event.returnValue=false;" >test</a> |
說明:
1.javascript:void(0)這種偽協議,少寫的好,如果你看過一些web標準的書就知道為什麼了。(不懂,原話摘的,暫做記錄)
2.連結(href)直接使用javascript:void(0)在IE中可能會引起一些問題,比如:造成gif動畫停止播放等,所以,最安全的辦法還是使用“####”。為防止點選連結後跳轉到頁首,onclick事件return false即可。
3.如果僅僅是想滑鼠移過,變成手形,可以使用
<span style="cursor:pointer" onclick="foo()">Click Me!</span>
?
void是javascript的操作符,意思是:只執行運算式,但沒有傳回值,
void 操作符用法格式如下:
?
12 |
javascript:void (expression) javascript:void expression |
為了程式風格良好,建議使用第二種帶上括弧的
我們可以使用void操作符指定超級連結,如javascript:void(document.form.submit())。運算式會被計算但是不會在當前文檔處裝入任何內容,void(0)計算為0,但在JavaScript上沒有任何效果,也就是說 <a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是一樣的。
關鍵是只要知道void是javascipt自身的操作符,它表示的是只執行運算式,但沒有傳回值!
另外頁面會自動調回頂端,是因為"#"預設的瞄點位置是top,所以會出現這種情況。 ?
繼續解釋
我想使用過ajax的都常見這樣的代碼:
<a href="javascript:doTest2();void(0);">here</a>
但這兒的void(0)究竟是何含義呢?
Javascript中void是一個操作符,該操作符指定要計算一個運算式但是不傳回值。
void 操作符用法格式如下:
1. javascript:void (expression)
2. javascript:void expression
expression 是一個要計算的 Javascript 標準的運算式。運算式外側的圓括弧是選的,但是寫上去是一個好習慣。 (實現版本 Navigator 3.0 )
你以使用 void 操作符指定超級連結。運算式會被計算但是不會當前文檔處裝入任何內容。
下面的代碼建立了一個超級連結,當使用者以後不會發生任何事。當使用者連結時,void(0) 計算為 0,但 Javascript 上沒有任何效果。
<A HREF="javascript:void(0)">單此處什麼也不會發生</A>
下面的代碼建立了一個超級連結,使用者單時會提交表單。
<A HREF="javascript:void(document.form.submit())">單此處提交表單</A>
a href=#與 a href=javascript:void(0) 的區別 連結的幾種辦法
#包含了一個位置資訊
預設的錨是#top 也就是網頁的上端
而javascript:void(0) 僅僅表示一個死連結
這就是為什麼有的時候頁面很長瀏覽連結明明是#是
跳動到了頁首
而javascript:void(0) 則不是如此
所以呼叫指令碼的時候最好用void(0)
或者<input onclick>
<div onclick>等
連結的幾種辦法
1.window.open(‘‘url‘‘)
2.用自訂函數
?
12345678 |
<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)">株洲</a>
window.location.href=""
href=”#”,包含了一個位置資訊.預設的錨是#top,也就是網頁的上端,當連續快速點擊此連結時會導致瀏覽器巨慢甚至崩潰。
當然我們一般用三個 href="###",不過看了這篇文章我們以後就可以使用javascript:;(一個冒號一個分號)
javascript中void是一個操作符,該操作符指定要計算一個運算式但是不傳回值。
javascript:;好些,javascript:void(0);據說某些情況下有瀏覽器安全色bug。(此點bug我也不知道什麼時候能出現,知道的童鞋請指教)。
可以寫成javascript:;,qq空間很多都是寫成javascript:;
我感覺這兩者之間沒有什麼差別,都是執行一個空事件。
javascript:;甚至少了7個字元,呵呵。
新浪微博寫的是javascript:void(0);
我以前一直寫的是javascript:void(0);但是現在寫的都是javascript:;
a href="#"> 點選連結後,頁面會向上滾到頁首,# 預設錨點為 #TOP
<a href="javascript:void(0)" onClick="window.open()"> 點選連結後,頁面不動,只開啟連結
<a href="#" onclick="javascript:return false;"> 作用同上,不同瀏覽器會有差異。
點選連結後,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有類似作用
詳解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)
今天調試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:方法"
您可能感興趣的文章:
- Java中的裝箱和拆箱深入理解
- 淺談Java自動裝箱與拆箱及其陷阱
- java自動裝箱拆箱深入剖析
- Java Regex詳解
- java使double保留兩位小數的多方法 java保留兩位小數
- JAVA8 十大新特性詳解
- Java環境變數的設定方法(圖文教程)
- java寫入檔案的幾種方法分享
- java中File類的使用方法
- java list用法樣本詳解
- Java 裝箱與拆箱詳解及執行個體代碼
【repost】javascript:;與javascript:void(0)使用介紹