溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JQuery事件委托的示例分析

發(fā)布時間:2021-06-15 14:02:06 來源:億速云 閱讀:155 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關JQuery事件委托的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

最近一段時間打了一個大仗,現(xiàn)在總算消停點,才有時間來做個總結吧算是:

移動端遇到一個項目,是一個列表的側滑欄,在我這里用jq寫的交互事件。自測各方面都挺好的,美滋滋的給了研發(fā)。研發(fā)也美滋滋的開始開發(fā)。

但是,好景不長。。。

研發(fā)加了ajax事件后,我的交互效果有部分受了影響!

一個小姑娘,在一群大老爺們研發(fā)堆里,對著昏暗的電腦和看不太懂的后臺代碼,改了半天。最后沒解決。我就回來了。

后來就找共同點,發(fā)現(xiàn)有個類名控制的交互都不能實現(xiàn),最后去問研發(fā),你是不是沒加上我的類名?

回:加著呢啊!我一看模擬器,確實加著呢。但是看源碼,沒有,因為他使用ajax后期加的。。所以一開始事件找不到“接頭人”就沒有執(zhí)行。

掃噶,定位到問題,就好解決了。

之所以整理成隨筆,是因為我之前沒遇到過這個問題,聽過事件委托機制,但是根本沒研究過不知道適用于什么樣的bug場景。今天逮到了就不能放過!

jq寫了點擊事件,是通過獲取元素的類名被點擊后執(zhí)行對應方法,但是研發(fā)套完模板,他會把所有的結構先清空,導致jq根本找不到那個元素,所以事件就不得執(zhí)行了。

正規(guī)點的說:JS異步加載,JQ事件不被執(zhí)行解決方法(百度的標題,hah)

jquery中動態(tài)新增的元素節(jié)點無法觸發(fā)事件問題(同上) 

解決方法:

JQuery事件委托的示例分析

JQuery事件委托的示例分析

值得注意的是:親測此方法無效,可能是我用的jq的版本太高了,1.9多,已經(jīng)不支持這個方法了

第二個方法:

JQuery事件委托的示例分析

但是缺點是:給一個元素添加多個事件委托機制時,他就掛了。

$("div").delegate("button","click",function(){
 console.log("start")
})

div下面的button點擊的時候,打印start,這個button可以是動態(tài)生成的

王者方法:on

JQuery事件委托的示例分析

感謝各位的閱讀!關于“JQuery事件委托的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI