五月综合缴情婷婷六月,色94色欧美sute亚洲线路二,日韩制服国产精品一区,色噜噜一区二区三区,香港三级午夜理伦三级三

您現(xiàn)在的位置: 365建站網(wǎng) > 365文章 > javascript:;與javascript:void(0)使用介紹

javascript:;與javascript:void(0)使用介紹

文章來源:365jz.com     點(diǎn)擊數(shù):281    更新時(shí)間:2017-08-11 10:52   參與評(píng)論

最近看了好幾個(gè)關(guān)于<a>標(biāo)簽和javascript:void(0)的帖子,謹(jǐn)記于此,以資查閱。
注:以下代碼未經(jīng)全面測試,但每一種方法可能會(huì)出現(xiàn)的情況都基本做了說明。
在做頁面時(shí),如果想做一個(gè)鏈接點(diǎn)擊后不做任何事情,或者響應(yīng)點(diǎn)擊而完成其他事情,可以設(shè)置其屬性 href = "#",但是,這樣會(huì)有一個(gè)問題,就是當(dāng)頁面有滾動(dòng)條時(shí),點(diǎn)擊后會(huì)返回到頁面頂端,用戶體驗(yàn)不好。

目前有如下幾種解決辦法:

1)點(diǎn)擊鏈接后不做任何事情 

<a href="javascript:void(0);" >test</a> 
<a href="javascript:;" >test</a> 
<a href="####" >test</a> //使用2個(gè)到4個(gè)#,見的大多是"####",也有使用"#all"等其他的 

 

2)點(diǎn)擊鏈接后,響應(yīng)用戶自定義的點(diǎn)擊事件

<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)這種偽協(xié)議,少寫的好,如果你看過一些web標(biāo)準(zhǔn)的書就知道為什么了。(不懂,原話摘的,暫做記錄)
2.鏈接(href)直接使用javascript:void(0)在IE中可能會(huì)引起一些問題,比如:造成gif動(dòng)畫停止播放等,所以,最安全的辦法還是使用“####”。為防止點(diǎn)擊鏈接后跳轉(zhuǎn)到頁首,onclick事件return false即可。
3.如果僅僅是想鼠標(biāo)移過,變成手形,可以使用

<span style="cursor:pointer" onclick="foo()">Click Me!</span>  
?
void是javascript的操作符,意思是:只執(zhí)行表達(dá)式,但沒有返回值,
void 操作符用法格式如下:

javascript:void (expression)  
javascript:void expression  

為了程序風(fēng)格良好,建議使用第二種帶上括號(hào)的
我們可以使用void操作符指定超級(jí)鏈接,如javascript:void(document.form.submit())。表達(dá)式會(huì)被計(jì)算但是不會(huì)在當(dāng)前文檔處裝入任何內(nèi)容,void(0)計(jì)算為0,但在JavaScript上沒有任何效果,也就是說 <a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是一樣的。
關(guān)鍵是只要知道void是javascipt自身的操作符,它表示的是只執(zhí)行表達(dá)式,但沒有返回值!
另外頁面會(huì)自動(dòng)調(diào)回頂端,是因?yàn)?quot;#"默認(rèn)的瞄點(diǎn)位置是top,所以會(huì)出現(xiàn)這種情況。 ?

繼續(xù)解釋

我想使用過ajax的都常見這樣的代碼:
<a href="javascript:doTest2();void(0);">here</a>
但這兒的void(0)究竟是何含義呢?

Javascript中void是一個(gè)操作符,該操作符指定要計(jì)算一個(gè)表達(dá)式但是不返回值。

void 操作符用法格式如下:

1. javascript:void (expression)
2. javascript:void expression

expression 是一個(gè)要計(jì)算的 Javascript 標(biāo)準(zhǔn)的表達(dá)式。表達(dá)式外側(cè)的圓括號(hào)是選的,但是寫上去是一個(gè)好習(xí)慣。 (實(shí)現(xiàn)版本   Navigator 3.0   )

你以使用 void 操作符指定超級(jí)鏈接。表達(dá)式會(huì)被計(jì)算但是不會(huì)當(dāng)前文檔處裝入任何內(nèi)容。

下面的代碼創(chuàng)建了一個(gè)超級(jí)鏈接,當(dāng)用戶以后不會(huì)發(fā)生任何事。當(dāng)用戶鏈接時(shí),void(0) 計(jì)算為 0,但 Javascript 上沒有任何效果。

<A HREF="javascript:void(0)">單此處什么也不會(huì)發(fā)生</A>

下面的代碼創(chuàng)建了一個(gè)超級(jí)鏈接,用戶單時(shí)會(huì)提交表單。

<A HREF="javascript:void(document.form.submit())">單此處提交表單</A>

a href=#與 a href=javascript:void(0) 的區(qū)別 鏈接的幾種辦法

#包含了一個(gè)位置信息

默認(rèn)的錨是#top 也就是網(wǎng)頁的上端

而javascript:void(0)   僅僅表示一個(gè)死鏈接

這就是為什么有的時(shí)候頁面很長瀏覽鏈接明明是#是

跳動(dòng)到了頁首

而javascript:void(0) 則不是如此

所以調(diào)用腳本的時(shí)候最好用void(0)

或者<input onclick>

<div onclick>等

鏈接的幾種辦法
1.window.open(''url'')

2.用自定義函數(shù)

<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=”#”,包含了一個(gè)位置信息.默認(rèn)的錨是#top,也就是網(wǎng)頁的上端,當(dāng)連續(xù)快速點(diǎn)擊此鏈接時(shí)會(huì)導(dǎo)致瀏覽器巨慢甚至崩潰。

當(dāng)然我們一般用三個(gè) href="###",不過看了這篇文章我們以后就可以使用javascript:;(一個(gè)冒號(hào)一個(gè)分號(hào))

javascript中void是一個(gè)操作符,該操作符指定要計(jì)算一個(gè)表達(dá)式但是不返回值。

javascript:;好些,javascript:void(0);據(jù)說某些情況下有瀏覽器兼容bug。(此點(diǎn)bug我也不知道什么時(shí)候能出現(xiàn),知道的童鞋請(qǐng)指教)。

可以寫成javascript:;,qq空間很多都是寫成javascript:;
我感覺這兩者之間沒有什么差別,都是執(zhí)行一個(gè)空事件。
javascript:;甚至少了7個(gè)字符,呵呵。

新浪微博寫的是javascript:void(0);

我以前一直寫的是javascript:void(0);但是現(xiàn)在寫的都是javascript:;

a href="#"> 點(diǎn)擊鏈接后,頁面會(huì)向上滾到頁首,# 默認(rèn)錨點(diǎn)為 #TOP
<a href="javascript:void(0)" onClick="window.open()"> 點(diǎn)擊鏈接后,頁面不動(dòng),只打開鏈接
<a href="#" onclick="javascript:return false;"> 作用同上,不同瀏覽器會(huì)有差異。

點(diǎn)擊鏈接后,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有類似作用

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

"#"包含了一個(gè)位置信息
默認(rèn)的錨點(diǎn)是#top 也就是網(wǎng)頁的上端
而javascript:void(0) 僅僅表示一個(gè)死鏈接
這就是為什么有的時(shí)候頁面很長瀏覽鏈接明明是??墒翘鴦?dòng)到了頁首
而javascript:void(0) 則不是如此
所以調(diào)用腳本的時(shí)候最好用void(0)
或者<input onclick>
<div onclick>等
打開新窗口鏈接的幾種辦法
1.window.open('url')
2.用自定義函數(shù)

 


        <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="" 如果是個(gè)# ,就會(huì)出現(xiàn)跳到頂部的情況,個(gè)人收藏的幾種解決方法: 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) 今天調(diào)試CGI的時(shí)候,明明CGI程序已經(jīng)執(zhí)行,并且最后結(jié)果也是正確的,但是頁面就是不刷新。在FireFox2.0下測試,結(jié)果卻是正常的,IE6卻偏偏不刷新!仔細(xì)調(diào)查了一下,發(fā)現(xiàn)cgi頁面鏈接的是 <a href="javaScript:void(0)" OnClick="XXX_Func();" ….> only a sample </a>,問題就出在這個(gè)void(0)上!讓我們先來看看JavaScript中void(0)的含義: JavaScript中void是一個(gè)操作符,該操作符指定要計(jì)算一個(gè)表達(dá)式但是不返回值。 void 操作符用法格式如下: 1. javascript:void (expression_r_r) 2. javascript:void expression_r_r expression_r_r是一個(gè)要計(jì)算的 JavaScript 標(biāo)準(zhǔn)的表達(dá)式。表達(dá)式外側(cè)的圓括號(hào)是可選的,但是寫上去是一個(gè)好習(xí)慣。我們可以使用 void 操作符指定超級(jí)鏈接。表達(dá)式會(huì)被計(jì)算但是不會(huì)在當(dāng)前文檔處裝入任何內(nèi)容。面的代碼創(chuàng)建了一個(gè)超級(jí)鏈接,當(dāng)用戶點(diǎn)擊以后不會(huì)發(fā)生任何事。當(dāng)用戶點(diǎn)擊鏈接時(shí),void(0) 計(jì)算為 0,但在 JavaScript 上沒有任何效果。 <a href="javascript:void(0)">單擊此處什么也不會(huì)發(fā)生</a> 也就是說,要執(zhí)行某些處理,但是不整體刷新頁面的情況下,可以使用void(0),但是在需要對(duì)頁面進(jìn)行refresh的情況下,那就要仔細(xì)了。 其實(shí)我們可以這樣用<a href="javascript:void(document.form.submit())">,這句話會(huì)進(jìn)行一次submit操作。那什么情況下用void(0)比較多呢,無刷新,當(dāng)然是Ajax了,看一下Ajax的web頁面的話,一般都會(huì)看到有很多的void(0),:) ,所以在使用void(0)之前,最好先想一想,這個(gè)頁面是否需要整體刷新。

 使用javascript的時(shí)候,通常我們會(huì)通過類似: <a href="#" onclick="javascript:方法">提交</a> 的方式,通過一個(gè)偽鏈接來調(diào)用javascript方法.這種方法有一個(gè)問題是: 雖然點(diǎn)擊該鏈接的時(shí)候不會(huì)跳轉(zhuǎn)頁面.但是滾動(dòng)條會(huì)往上滾,解決的辦法是返回一個(gè)false. 如下所示: <a href="#" onclick="javascript:方法;return false;">提交</a>

還可以用 ###

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

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

如對(duì)本文有疑問,請(qǐng)?zhí)峤坏浇涣髡搲瑥V大熱心網(wǎng)友會(huì)為你解答??! 點(diǎn)擊進(jìn)入論壇

發(fā)表評(píng)論 (281人查看,0條評(píng)論)
請(qǐng)自覺遵守互聯(lián)網(wǎng)相關(guān)的政策法規(guī),嚴(yán)禁發(fā)布色情、暴力、反動(dòng)的言論。
昵稱:
最新評(píng)論
------分隔線----------------------------

其它欄目

· 建站教程
· 365學(xué)習(xí)

業(yè)務(wù)咨詢

· 技術(shù)支持
· 服務(wù)時(shí)間:9:00-18:00
365建站網(wǎng)二維碼

Powered by 365建站網(wǎng) RSS地圖 HTML地圖

copyright © 2013-2024 版權(quán)所有 鄂ICP備17013400號(hào)