在jQuery中,on是一個非常重要的事件綁定函數(shù),可以用來綁定事件和處理事件。但有時候會出現(xiàn)一個奇怪的問題,即on會執(zhí)行兩次,這在開發(fā)中經(jīng)常會讓人困擾。
造成on執(zhí)行兩次的原因很多,其中一個常見的原因是因為事件冒泡。當(dāng)有多個父元素綁定了該事件,事件就會沿著父元素繼續(xù)冒泡并執(zhí)行。這時候,如果不加控制,on事件就會被執(zhí)行兩次或多次,導(dǎo)致代碼出錯。
$('#parent').on('click', '#child', function() {
console.log('click');
});
上面代碼中,鎖定了一個父元素并在它內(nèi)部找到一個子元素進行事件綁定,當(dāng)點擊子元素時,on事件就會被觸發(fā)。但如果有多個#parent元素都匹配了這個選擇器,事件就會觸發(fā)多次。
為了解決這個問題,需要在on事件中加上一個stopPropagation()方法,來阻止事件向父元素冒泡。代碼如下:
$('#parent').on('click', '#child', function(event) {
event.stopPropagation();
console.log('click');
});
通過加上stopPropagation()方法,事件就不會再向上冒泡,從而避免了事件被執(zhí)行多次的問題。