国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

關于動態生成dom綁定事件失效的原因及解決方法

2019-11-20 09:17:37
字體:
來源:轉載
供稿:網友

之前做項目都是直接用jquery的bind綁定事件,不過當時都不是動態生成dom元素,而是已經頁面中原本存在的dom元素進行事件綁定,最近在測試給動態生成的dom綁定事件的時候發現事件失效,于是就測試了一下:

1. 事件失效的原因:

(1)bind事件綁定只對dom中存在的元素有效,對于我們后來動態增加的元素是監測不到,所以綁定不了

(2)同樣,當你使用var aa = document.getElementsByTagName("動態生成的元素");來獲取動態生成的元素的時候也是獲取不到的,因為網頁只會執行一次初始化綁定,之后動態生成的dom元素也是監測不到的。

2. 解決辦法:

(1)在每一個動態生成的地方都再綁定多一次事件,比如這個博客里面的例子

(2)把bind改用live,因為live是實時監測的,對于新增的dom元素也是有效的(因為不斷去綁定、判斷,所以可能會影響Web性能問題)

(3)把bind改用delegate,因為delegate是實時監測的。

(4)在jquery1.7 起版本用on替代了bind()、live() 和 delegate() 方法。

3. 關于最近遇到的事件失效的原因:在原本的網頁中(代碼可見https://github.com/UFOwl/ife/tree/master/stage02/task16),我想要獲取table里面動態生成的刪除按鈕,幫刪除按鈕綁定刪除時間,可是刪除事件失效,因為刪除按鈕是動態生成的,初始化事件綁定的時候,獲取到的table里面的button已經是空的,所以綁定的一直都是空元素,所以點擊button按鈕的時候一直沒有反應。

4. 最后的解決辦法:先獲取table,然后再綁定table的click事件(因為table是在原本已經存在的dom元素),然后當點擊事件觸發的時候再捕獲事件的target(比如點擊table里面的button,這個時候因為已經動態生成button并append進去table里面了,所以button是存在的,此時target指的是button),然后再進行相應的操作。

注意:在這里注意兩個問題:

(1)table里面的元素是已經添加進入table里面了的,所以點擊那個button的時候,e.target獲取到的就是button

(2)為什么已經將button這些元素添加進入table里面,可是還是沒能獲取到呢,因為是init()這個函數初始化的時候獲取table里面的button,可是此時還未進行任何操作,所以獲取到的就是空,所以沒綁定任何元素。

上面需要注意的兩個問題要分清楚,這個是問題的關鍵。

5.關于bind:每次綁定事件之后事件會一直綁定著,除非用unbind解綁之后再重新綁定,要不然事件會一直存在,所以這就是為什么在做項目的時候,有時候ajax請求的結果會出現1,2,4,8這樣疊加,是因為如果用了bind,每次觸發事件都會綁定一次操作,所以觸發第一次的時候,ajax請求一次;第二次的時候,ajax請求1+1=2次;第三次就是1+2+1=4次;第四次就是1+2+4+1=8次,以此類推。所以如果利用bind綁定事件的話,要先unbind解綁元素原本有的事件再綁定事件,才不會導致ajax請求多次。

以上這篇關于動態生成dom綁定事件失效的原因及解決方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 来宾市| 荥阳市| 德格县| 大竹县| 塘沽区| 贺州市| 延边| 武功县| 靖州| 嘉义市| 封丘县| 稻城县| 云阳县| 贞丰县| 武定县| 渝中区| 关岭| 吴忠市| 乃东县| 忻州市| 神池县| 永新县| 渝北区| 兖州市| 工布江达县| 宜良县| 和静县| 湘乡市| 布尔津县| 鄄城县| 苍梧县| 铜梁县| 公安县| 五莲县| 延吉市| 萝北县| 巩义市| 新蔡县| 萨嘎县| 桐梓县| 天气|