課程
/前端開發(fā)
/JavaScript
/JavaScript進階篇
onclick事件如何中的a標(biāo)簽怎么用的呢
2016-04-06
源自:JavaScript進階篇 6-1
正在回答
我們常用的在a標(biāo)簽中有點擊事件:1. a href="javascript:js_method();"這是我們平臺上常用的方法,但是這種方法在傳遞this等參數(shù)的時候很容易出問題,而且javascript:協(xié)議作為a的href屬性的時候不僅會導(dǎo)致 不必要的觸發(fā)window.onbeforeunload事件,在IE里面更會使gif動畫圖片停止播放。W3C標(biāo)準(zhǔn)不推薦在href里面執(zhí)行 javascript語句2. a href="javascript:void(0);" onclick="js_method()"這種方法是很多網(wǎng)站最常用的方法,也是最周全的方法,onclick方法負(fù)責(zé)執(zhí)行js函數(shù),而void是一個操作符,void(0)返回undefined,地址不發(fā)生跳轉(zhuǎn)。而且這種方法不會像第一種方法一樣直接將js方法暴露在瀏覽器的狀態(tài)欄。3.a href="javascript:;" onclick="js_method()"這種方法跟跟2種類似,區(qū)別只是執(zhí)行了一條空的js代碼。4.a href="#" onclick="js_method()"這種方法也是網(wǎng)上很常見的代碼,#是標(biāo)簽內(nèi)置的一個方法,代表top的作用。所以用這種方法點擊后網(wǎng)頁后返回到頁面的最頂端。5.a href="#" onclick="js_method();return false;"這種方法點擊執(zhí)行了js函數(shù)后return false,頁面不發(fā)生跳轉(zhuǎn),執(zhí)行后還是在頁面的當(dāng)前位置。我看了下taobao的主頁,他們采用的是第2種方法,而alibaba的主頁是采用的第1種方法,和我們的區(qū)別是每個href里的javascript方法都用try、catch包圍。綜合上述,在a中調(diào)用js函數(shù)最適當(dāng)?shù)姆椒ㄍ扑]使用:a href="javascript:void(0);" onclick="js_method()"a href="javascript:;" onclick="js_method()"a href="#" onclick="js_method();return false;"
qq_不走尋常路_0 提問者
舉報
本課程從如何插入JS代碼開始,帶您進入網(wǎng)頁動態(tài)交互世界
2 回答a標(biāo)簽 href 調(diào)用 JS函數(shù)失敗 <a href="javascript:hh(); ">
3 回答a標(biāo)簽?????
2 回答a標(biāo)簽里面的onclick沒法用
1 回答創(chuàng)建a標(biāo)簽
4 回答a標(biāo)簽問題
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號-11 京公網(wǎng)安備11010802030151號
購課補貼聯(lián)系客服咨詢優(yōu)惠詳情
慕課網(wǎng)APP您的移動學(xué)習(xí)伙伴
掃描二維碼關(guān)注慕課網(wǎng)微信公眾號
2016-04-06
我們常用的在a標(biāo)簽中有點擊事件:
1. a href="javascript:js_method();"
這是我們平臺上常用的方法,但是這種方法在傳遞this等參數(shù)的時候很容易出問題,而且javascript:協(xié)議作為a的href屬性的時候不僅會導(dǎo)致 不必要的觸發(fā)window.onbeforeunload事件,在IE里面更會使gif動畫圖片停止播放。W3C標(biāo)準(zhǔn)不推薦在href里面執(zhí)行 javascript語句
2. a href="javascript:void(0);" onclick="js_method()"
這種方法是很多網(wǎng)站最常用的方法,也是最周全的方法,onclick方法負(fù)責(zé)執(zhí)行js函數(shù),而void是一個操作符,void(0)返回undefined,地址不發(fā)生跳轉(zhuǎn)。而且這種方法不會像第一種方法一樣直接將js方法暴露在瀏覽器的狀態(tài)欄。
3.a href="javascript:;" onclick="js_method()"
這種方法跟跟2種類似,區(qū)別只是執(zhí)行了一條空的js代碼。
4.a href="#" onclick="js_method()"
這種方法也是網(wǎng)上很常見的代碼,#是標(biāo)簽內(nèi)置的一個方法,代表top的作用。所以用這種方法點擊后網(wǎng)頁后返回到頁面的最頂端。
5.a href="#" onclick="js_method();return false;"
這種方法點擊執(zhí)行了js函數(shù)后return false,頁面不發(fā)生跳轉(zhuǎn),執(zhí)行后還是在頁面的當(dāng)前位置。
我看了下taobao的主頁,他們采用的是第2種方法,而alibaba的主頁是采用的第1種方法,和我們的區(qū)別是每個href里的javascript方法都用try、catch包圍。
綜合上述,在a中調(diào)用js函數(shù)最適當(dāng)?shù)姆椒ㄍ扑]使用:
a href="javascript:void(0);" onclick="js_method()"
a href="javascript:;" onclick="js_method()"
a href="#" onclick="js_method();return false;"