欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery移除button的inline onclick事件(已測(cè)試及兼容瀏覽器)

 更新時(shí)間:2013年01月25日 15:06:44   作者:  
這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會(huì)馬上調(diào)用reclick方法,這不是我們想要的效果;為了解決這個(gè)問(wèn)題,我們可以換個(gè)思路,就是延遲綁定click事件

inline onclick代碼如下

復(fù)制代碼 代碼如下:

<input type="button" id="btnOK" name="" value="確定" onclick="btnOKClick();" />

btnOKClick的代碼
復(fù)制代碼 代碼如下:

function btnOKClick() {
alert("btnOK Clicked");
}

現(xiàn)在要在點(diǎn)擊按鈕以后,移除onclick事件,并為按鈕綁定一個(gè)新的click事件。在第二次點(diǎn)擊時(shí)候,就開(kāi)始執(zhí)行第二個(gè)事件處理函數(shù),第二個(gè)處理函數(shù)的代碼:
reclick的代碼
復(fù)制代碼 代碼如下:

function reclick() {
alert('reclick');
}
[\s\S ]*\n

思路:在btnOKClick中移除onclick,然后添加新的綁定,代碼如下:
復(fù)制代碼 代碼如下:

$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });

加上這段代碼后的btnOKClick方法如下:
復(fù)制代碼 代碼如下:

function btnOKClick() {
alert("btnOK Clicked");
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
}

這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會(huì)馬上調(diào)用reclick方法,這不是我們想要的效果。

出現(xiàn)這種效果的原因貌似是因?yàn)閛nclick執(zhí)行完了以后,IE回去查看是否有綁定在click上的handler,結(jié)構(gòu)是有的,于是就馬上執(zhí)行了。

為了解決這個(gè)問(wèn)題,我們可以換個(gè)思路,就是延遲綁定click事件。具體的代碼如下:
復(fù)制代碼 代碼如下:

function btnOKClick() {
alert("btnOK Clicked");
setTimeout(function () {
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
}, 1);
}

這里使用了setTimeout定時(shí)器,在定時(shí)器觸發(fā)以后,才執(zhí)行移除onclick屬性,綁定click handler的代碼。
經(jīng)測(cè)試,在IE9的兼容模式和非兼容模式下都可以正常運(yùn)行;Google Chrome也正常運(yùn)行。

相關(guān)文章

最新評(píng)論