jquery移除button的inline onclick事件(已測試及兼容瀏覽器)
更新時間:2013年01月25日 15:06:44 作者:
這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會馬上調用reclick方法,這不是我們想要的效果;為了解決這個問題,我們可以換個思路,就是延遲綁定click事件
inline onclick代碼如下:
復制代碼 代碼如下:
<input type="button" id="btnOK" name="" value="確定" onclick="btnOKClick();" />
btnOKClick的代碼:
復制代碼 代碼如下:
function btnOKClick() {
alert("btnOK Clicked");
}
現(xiàn)在要在點擊按鈕以后,移除onclick事件,并為按鈕綁定一個新的click事件。在第二次點擊時候,就開始執(zhí)行第二個事件處理函數(shù),第二個處理函數(shù)的代碼:
reclick的代碼:
復制代碼 代碼如下:
function reclick() {
alert('reclick');
}
[\s\S ]*\n
思路:在btnOKClick中移除onclick,然后添加新的綁定,代碼如下:
復制代碼 代碼如下:
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
加上這段代碼后的btnOKClick方法如下:
復制代碼 代碼如下:
function btnOKClick() {
alert("btnOK Clicked");
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
}
這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會馬上調用reclick方法,這不是我們想要的效果。
出現(xiàn)這種效果的原因貌似是因為onclick執(zhí)行完了以后,IE回去查看是否有綁定在click上的handler,結構是有的,于是就馬上執(zhí)行了。
為了解決這個問題,我們可以換個思路,就是延遲綁定click事件。具體的代碼如下:
復制代碼 代碼如下:
function btnOKClick() {
alert("btnOK Clicked");
setTimeout(function () {
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
}, 1);
}
這里使用了setTimeout定時器,在定時器觸發(fā)以后,才執(zhí)行移除onclick屬性,綁定click handler的代碼。
經(jīng)測試,在IE9的兼容模式和非兼容模式下都可以正常運行;Google Chrome也正常運行。
相關文章
jQuery EasyUI API 中文文檔 - Panel面板
jQuery EasyUI API 中文文檔 - Panel面板,使用jQuery EasyUI的朋友可以參考下。2011-09-09jQuery實現(xiàn)倒計時功能 jQuery實現(xiàn)計時器功能
這篇文章主要為大家詳細介紹了jQuery實現(xiàn)倒計時功能,jQuery實現(xiàn)計時器功能的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09JQuery異步加載無限下拉框級聯(lián)功能實現(xiàn)示例
這篇文章主要介紹了JQuery異步加載無限下拉框級聯(lián)功能的實現(xiàn),需要的朋友可以參考下2014-02-02