关于jQuery新的事件绑定机制on()的使用技巧
今天浏览jQuery的deprecated列表,发现live()和die()在里面了,赶紧看了一下,发现从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定。因为在此之前有bind(),live(),delegate()等方法来处理事件绑定,jQuery从性能优化以及方式统一方面考虑决定推出新的函数来统一事件绑定方法并且替换掉以前的方法。
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()一样的效果。
$("#listli").live("click","#listli",function(){
//functioncodehere.
});
$(document).on("click","#listli",function(){
//functioncodehere.
});
这里的关键就是第二个参数"selector"在起作用了。它是一个过滤器的作用,只有被选中元素的后代元素才会触发事件。
$("#list").delegate("li","click",function(){
//functioncodehere.
});
$("#list").on("click","li",function(){
//functioncodehere.
});
貌似第一个和第二个参数的顺序颠倒了一下,别的基本一样。
相关文章
- 使用 jquery 获取一组或者单个 checkbox 的选中状态的值详解编程语言
- JQuery添加事件监听详解编程语言
- jQuery on和trigger添加触发自定义事件
- jQuery parent() parents()和parentsUntil()方法
- 让网站动起来!12款优秀的 jQuery 动画插件推荐
- JQuery绑定事件时传递参数的实现方法
- jQuery温习篇强大的JQuery选择器
- jquery$.ajax各个事件执行顺序
- 用JQuery调用Session的实现代码
- Jquery知识点三jquery表单对象操作
- jquery键盘事件介绍
- 基于jquery循环map功能的代码
- jQuery的运行机制和设计理念分析
- jQuery中绑定事件的命名空间详解
- jQuery判断元素是否是隐藏的代码
- Jquery实现三层遍历删除功能代码
- 模拟电子签章盖章效果的jQuery插件源码
- jquery获取被勾选的checked(选中)的那一行的3列和4列的值
- jQuery绑定事件到动态创建的元素上的方法实例
- jQuery操作Select的Option上下移动及移除添加等等
- js阻止冒泡及jquery阻止事件冒泡示例介绍
- jQuery中阻止冒泡事件的方法介绍
- jQuery制作的别致导航有阴影背景高亮模式窗口
- jquery文本框中的事件应用以输入邮箱为例
- jquery动态添加元素事件失效问题解决方法
- jQuery不兼容input的change事件问题解决过程
- jQuery学习总结之jQuery事件
- jQuery的animate函数学习记录
- JQuery拖动表头边框线调整表格列宽效果代码