jquery新的绑定事件机制on方法的使用方法
浏览jQuery的deprecated列表,发现live()和die()在里面了,赶紧看了一下,发现从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定。因为在此之前有bind(),live(),delegate()等方法来处理事件绑定,jQuery从性能优化以及方式统一方面考虑决定推出新的函数来统一事件绑定方法并且替换掉以前的方法。
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()写法
$("#listli").live("click","#listli",function(){
//functioncodehere.
});
on()写法
$(document).on("click","#listli",function(){
//functioncodehere.
});
这里的关键就是第二个参数"selector"在起作用了。它是一个过滤器的作用,只有被选中元素的后代元素才会触发事件。
替换delegate()
delegate()是1.4引入的,目的是通过祖先元素来代理委派后代元素的事件绑定问题,某种程度上和live()优点相似。只不过live()是通过document元素委派,而delegate则可以是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。
delegate()的写法
$("#list").delegate("li","click",function(){
//functioncodehere.
});
on()写法
$("#list").on("click","li",function(){
//functioncodehere.
});
貌似第一个和第二个参数的顺序颠倒了一下,别的基本一样。
总结
jQuery推出on()的目的有2个,一是为了统一接口,二是为了提高性能,所以从现在开始用on()替换bind(),live(),delegate吧。尤其是不要再用live()了,因为它已经处于不推荐使用列表了,随时会被干掉。如果只绑定一次事件,那接着用one()吧,这个没有变化。
相关文章
- jquery事件delegate()方法用法详解[通俗易懂]
- jquery关于移动端的点击事件解析详解编程语言
- jQuery keydown和keyup事件
- jQuery contextmenu事件详解
- jQuery one()方法绑定事件(仅触发一次)
- jQuery判断元素上是否绑定了事件
- js和jquery批量绑定事件传参数一(新猪猪原创)
- 初窥JQuery(二)事件机制(1)
- jquery的键盘事件修改代码
- jquery笔记事件
- jquery的冒泡事件的阻止与允许(三种实现方法)
- jQuery用unbind方法去掉hover事件及其他方法介绍
- Struts2的s:radio标签使用及用jquery添加change事件
- jQuery学习笔记(4)--Jquery中获取table中某列值的具体思路
- 对jQuery的事件绑定的一些思考(补充)
- jQuery文本框(inputtextare)事件绑定方法教程
- jQuery绑定事件到动态创建的元素上的方法实例
- ff下JQuery无法监听input的keyup事件的解决方法
- 解析jQuery的三种bind/One/Live事件绑定使用方法
- 不要使用jQuery触发原生事件的方法
- jquery移除、绑定、触发元素事件使用示例详解
- jQuery事件绑定和委托实例
- jquery事件preventDefault()方法用法实例
- jQuery实现长按按钮触发事件的方法