资源描述:
《jqueryon()绑定动态元素出现的问题小结_jquery》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、jQueryon()绑定动态元素出现的问题小结jQueryon()方法是官方推荐的绑定事件的一个方法。使用on()方法可以给将来动态创建的动态元素绑定指定的事件,例如append等。Z前使用on的时候一直是$(〃〃).on('click,,'function(){}')Z后发现有些时候一直无法绑定(比如元素动态生成时),查看文档后发现正确用法应该是$(document).on(〃change〃,〃#pageSize_out〃,function(){if($(〃#page_out〃)・val()!=0){$("#page
2、Size").val($(this).val());list();}})同时,注意Asthisanswersreceivesalotofattcntion,herearetwosupplementaryadvises:1)Whenit'spossible,trytobindtheeventlistenertothemostpreciseelement,toavoiduselesseventhandling.Thatis,ifyou'readdinganelementofclassbtoamexistinge1ement
3、ofida,thendon'tuse$(document.body).on('click','・b',function(){butuse$('#a')・on('click,,‘・b',function(){2)Becareful,whenyouaddanelementwithanid,toensureyou,renotaddingittwice.Notonlyisit"illegal"inHTMLtohavetwoe1ementswiththesameidbutitbreaksalotofthings.Forexamp
4、leaselectorwouldretrieveonlyoneelementwiththisid.on(events,[selector],[data],fn)events:一个或多个用空格分隔的事件类型和可选的命名空间,如〃click〃或"keydown.myPlugin"。selector:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。如果选择器为null或省略,当它到达选定的元素,事件总是触发。data:当一个事件被触发时要传递event,data给事件处理函数。fn:该事件被触发时执行的函数。fals
5、e值也可以做一个函数的简写,返冋false。替换bind()当第二个参数'selector'为null时,on()和bind()其实在用法上基本上没有任何区别了,所以我们可以认为on()只是比bindO多了一个可选的’selector参数,所以on()可以非常方便的换掉bindO替换liveO在1・4之前相信大家非常喜欢使用live(),因为它可以把事件绑定到当前以及以后添加的元素上而,当然在1.4Z后delegate()也可以做类似的事情了。liveO的原理很简单,它是通过document进行事件委派的,因此我们也可
6、以使用on()通过将事件绑定到document来达到liveO—样的效果。live。写法代码如下:$('#listli').live('click','#listli,,function(){//functioncodehere.});on()写法代码如下:$(document).on('click','#listli',function(){//functioncodehere.});这里的关键就是第二个参数'selector'在起作用了。它是一个过滤器的作用,只冇被选中元素的后代元素才会触发事件。替换delegat
7、e()delegate0是1.4引入的,目的是通过祖先元素來代理委派后代元素的事件绑定问题,某种程度上和1ive()优点相似。只不过live()是通过document元素委派,而delegate则可以是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。delegate()的写法代码如下:$('#list')・delegatefli','click',function(){//functioncodehere・});on()写法代码如下:$('#list')・on('click'li',funct
8、ion(){//functioncodeherc.});貌似第一个和第二个参数的顺序颠倒了一下,别的基本一样。总结jQuery推出on()的冃的有2个,一是为了统一接口,二是为了提高性能,所以从现在开始用on()替换bind(),live(),delegate吧。尤其是不要再用live()了,因为它己经处于不推荐使用列表了,随时会