在a標(biāo)簽的href與onclick中使用JavaScript的區(qū)別
發(fā)表時(shí)間:2024-01-02 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]在a標(biāo)簽的href與onclick中使用javascript的區(qū)別⒈ 鏈接的 onclick 事件被先執(zhí)行,其次是 href 屬性下的動(dòng)作(頁面跳轉(zhuǎn),或 javascript 偽鏈接);⒉ 假設(shè)鏈接中同時(shí)存在 href 與 onclick,如果想讓 href 屬性下的動(dòng)作不執(zhí)行,onclick...
在a標(biāo)簽的href與onclick中使用javascript的區(qū)別
⒈ 鏈接的 onclick 事件被先執(zhí)行,其次是 href 屬性下的動(dòng)作(頁面跳轉(zhuǎn),或 javascript 偽鏈接);
⒉ 假設(shè)鏈接中同時(shí)存在 href 與 onclick,如果想讓 href 屬性下的動(dòng)作不執(zhí)行,onclick 必須得到一個(gè) false 的返回值;
⒊ 如果頁面過長(zhǎng)有滾動(dòng)條,且希望通過鏈接的 onclick 事件執(zhí)行操作。應(yīng)將它的 href 屬性設(shè)為 javascript:void(0);,而不要是 #,這可以防止不必要的頁面跳動(dòng);
⒋ 如果在鏈接的 href 屬性中調(diào)用一個(gè)有返回值的函數(shù),當(dāng)前頁面的內(nèi)容將被此函數(shù)的返回值代替;
⒌ 在按住Shift鍵的情況下會(huì)有所區(qū)別。
⒍ 在IE6.0里以href的形式訪問不到parentNode。盡量不要用javascript:協(xié)議做為A的href屬性,這樣不僅會(huì)導(dǎo)致不必要的觸發(fā)window.onbeforeunload事件,在IE里面更會(huì)使gif動(dòng)畫圖片停止播放。就這些,花了不少時(shí)間在這上面。
(IE6下)
<a href="javascript:void(0);" onclick="javascript:modifypassword();"><img src="images/blue/Modify.gif"/></a>
此種寫法IE6下面URL雖然請(qǐng)求了后臺(tái),但是前臺(tái)沒有動(dòng)靜,
正確的寫法應(yīng)該為
<a href="javascript:void(0);" onclick="javascript:modifypassword();return false;"><img src="images/blue/Modify.gif"/></a>
個(gè)人收藏的幾個(gè)例子,供大家學(xué)習(xí)一下:
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)今天測(cè)試的時(shí)候,明明程序已經(jīng)執(zhí)行,并且最后結(jié)果也是正確的,但是頁面就是不刷新。
在FireFox2.0和ie7下測(cè)試,結(jié)果卻是正常的,IE6卻偏偏不刷新!仔細(xì)調(diào)查了一下,發(fā)現(xiàn)頁面鏈接的是 <a href="javaScript:void(0)" OnClick="XXX_Func();" ….> 測(cè)試 </a>,問題就出在這個(gè)void(0)上!
讓我們先來看看JavaScript中void(0)的含義:JavaScript中void是一個(gè)操作符,該操作符指定要計(jì)算一個(gè)表達(dá)式但是不返回值。
void 操作符用法格式如下:
1. javascript:void (e-xpression)
2. javascript:void e-xpression
e-xpression是一個(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è)頁面是否需要整體刷新。
以上就是在a標(biāo)簽的href與onclick中使用JavaScript的區(qū)別的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
網(wǎng)站建設(shè)是一個(gè)廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。