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

首頁 > 編程 > JavaScript > 正文

jQuery on()綁定動態元素出現的問題小結

2019-11-20 10:34:00
字體:
來源:轉載
供稿:網友

jQuery on()方法是官方推薦的綁定事件的一個方法。使用 on() 方法可以給將來動態創建的動態元素綁定指定的事件,例如append等。

之前使用 on 的時候一直是

$("").on('click','function(){ }') 

之后發現有些時候一直無法綁定(比如元素動態生成時),查看文檔后發現正確用法應該是

$(document).on("change","#pageSize_out",function(){ if($("#page_out").val()!=0){ $("#pageSize").val($(this).val()); list(); } }) 

同時,注意

As this answers receives a lot of attention, here are two supplementary advises :

1) When it's possible, try to bind the event listener to the most precise element, to avoid useless event handling.

That is, if you're adding an element of class b to an existing element of id a, then don't use$(document.body).on('click', '#a .b', function(){but use$('#a').on('click', '.b', function(){

2) Be careful, when you add an element with an id, to ensure you're not adding it twice. Not only is it "illegal" in HTML to have two elements with the same id but it breaks a lot of things. For example a selector "#c" would retrieve only one element with this id.

on(events,[selector],[data],fn)

events:一個或多個用空格分隔的事件類型和可選的命名空間,如"click"或"keydown.myPlugin" 。
selector:一個選擇器字符串用于過濾器的觸發事件的選擇器元素的后代。如果選擇器為null或省略,當它到達選定的元素,事件總是觸發。

data:當一個事件被觸發時要傳遞event.data給事件處理函數。

fn:該事件被觸發時執行的函數。 false 值也可以做一個函數的簡寫,返回false。

替換bind()

當第二個參數'selector'為null時,on()和bind()其實在用法上基本上沒有任何區別了,所以我們可以認為on()只是比bind()多了一個可選的'selector'參數,所以on()可以非常方便的換掉bind()

替換live()

在1.4之前相信大家非常喜歡使用live(),因為它可以把事件綁定到當前以及以后添加的元素上面,當然在1.4之后delegate()也可以做類似的事情了。live()的原理很簡單,它是通過document進行事件委派的,因此我們也可以使用on()通過將事件綁定到document來達到live()一樣的效果。

live()寫法

代碼如下:

$('#list li').live('click', '#list li', function() {//function code here.}); 

on()寫法

代碼如下:

$(document).on('click', '#list li', function() {//function code here.});

這里的關鍵就是第二個參數'selector'在起作用了。它是一個過濾器的作用,只有被選中元素的后代元素才會觸發事件。

替換delegate()

delegate()是1.4引入的,目的是通過祖先元素來代理委派后代元素的事件綁定問題,某種程度上和live()優點相似。只不過live()是通過document元素委派,而delegate則可以是任意的祖先節點。使用on()實現代理的寫法和delegate()基本一致。

delegate()的寫法

代碼如下:

$('#list').delegate('li', 'click', function() {//function code here.});

on()寫法

代碼如下:

$('#list').on('click', 'li', function() {//function code here.});

貌似第一個和第二個參數的順序顛倒了一下,別的基本一樣。

總結

jQuery推出on()的目的有2個,一是為了統一接口,二是為了提高性能,所以從現在開始用on()替換bind(), live(), delegate吧。尤其是不要再用live()了,因為它已經處于不推薦使用列表了,隨時會被干掉。如果只綁定一次事件,那接著用one()吧,這個沒有變化。

jquery on() 方法綁定動態元素

廢話不多說了,直接給大家貼代碼了。

<div id="test"><div class="evt">evt1</div></div>

錯誤的用法,下面方法只為第一個class 為 evt 的div 綁定了click事件,使用append動態創建的div則沒有綁定

<script>// 先綁定事件再添加div$('#test .evt').on('click', function() {alert($(this).text())});$('#test').append('<div class="evt">evt2</div>');</script>

正確的用法如下:

<script>$('body').on('click', '#test .evt', function() {alert($(this).text())});$('#test').append('<div class="evt">evt2</div>');</script>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 道真| 涿州市| 辽宁省| 通化县| 邛崃市| 渝中区| 琼海市| 汕尾市| 襄城县| 康乐县| 虹口区| 奉新县| 达州市| 龙江县| 博爱县| 威远县| 锡林郭勒盟| 文登市| 辽宁省| 连州市| 铜鼓县| 云南省| 竹山县| 扎兰屯市| 合山市| 泽州县| 靖江市| 新乡市| 荃湾区| 北辰区| 台南县| 大安市| 高碑店市| 阿尔山市| 南和县| 通城县| 靖安县| 荥经县| 吉木乃县| 望谟县| 乌拉特前旗|