DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> jquery移除button的inline onclick事件兼容浏覽器
jquery移除button的inline onclick事件兼容浏覽器
編輯:JQuery特效代碼     

inline onclick代碼如下

. 代碼如下:
<input type="button" id="btnOK" name="" value="確定" onclick="btnOKClick();" />

btnOKClick的代碼
. 代碼如下:
function btnOKClick() {
alert("btnOK Clicked");
}

現在要在點擊按鈕以後,移除onclick事件,並為按鈕綁定一個新的click事件。在第二次點擊時候,就開始執行第二個事件處理函數,第二個處理函數的代碼:
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方法,這不是我們想要的效果。

出現這種效果的原因貌似是因為onclick執行完了以後,IE回去查看是否有綁定在click上的handler,結構是有的,於是就馬上執行了。

為了解決這個問題,我們可以換個思路,就是延遲綁定click事件。具體的代碼如下:
. 代碼如下:
function btnOKClick() {
alert("btnOK Clicked");
setTimeout(function () {
$('#btnOK').attr('onclick', '').bind('click', function () { reclick(); });
}, 1);
}

這裡使用了setTimeout定時器,在定時器觸發以後,才執行移除onclick屬性,綁定click handler的代碼。
經測試,在IE9的兼容模式和非兼容模式下都可以正常運行;Google Chrome也正常運行。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved