jquery新的绑定事件机制on方法的使用方法


Posted in Javascript onApril 15, 2014

浏览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()写法

$('#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()吧,这个没有变化。

Javascript 相关文章推荐
自写简单JS判断是否已经弹出页面
Oct 20 Javascript
ASP.NET jQuery 实例5 (显示CheckBoxList成员选中的内容)
Jan 13 Javascript
关闭页面时window.location事件未执行的原因分析及解决方案
Sep 01 Javascript
纯JavaScript实现的兼容各浏览器的添加和移除事件封装
Mar 28 Javascript
js实现图片点击左右轮播
Jul 08 Javascript
使用Ajax与服务器(JSON)通信实例
Nov 04 Javascript
angularJS+requireJS实现controller及directive的按需加载示例
Feb 20 Javascript
JS获取短信验证码倒计时的实现代码
May 22 Javascript
javascript面向对象创建对象的方式小结
Jul 29 Javascript
ES6实现图片切换特效代码
Jan 14 Javascript
vue 封装 Adminlte3组件的实现
Mar 18 Javascript
React实现阿里云OSS上传文件的示例
Aug 10 Javascript
jquery datepicker参数介绍和示例
Apr 15 #Javascript
javascript调试之DOM断点调试法使用技巧分享
Apr 15 #Javascript
javascript页面渲染速度测试脚本分享
Apr 15 #Javascript
JS实现静止元素自动移动示例
Apr 14 #Javascript
js 获取元素下面所有li的两种方法
Apr 14 #Javascript
jQuery 鼠标经过(hover)事件的延时处理示例
Apr 14 #Javascript
jquery使用jxl插件导出excel示例
Apr 14 #Javascript
You might like
PHP读取RSS(Feed)简单实例
2014/06/12 PHP
php获取访问者IP地址汇总
2015/04/24 PHP
PHP实现移除数组中为空或为某值元素的方法
2017/01/07 PHP
PHP CURL与java http使用方法详解
2018/01/26 PHP
jquery在Chrome下获取图片的长宽问题解决
2013/03/20 Javascript
node.js抓取并分析网页内容有无特殊内容的js文件
2015/11/17 Javascript
JavaScript html5 canvas绘制时钟效果
2016/03/01 Javascript
js字符串操作总结(必看篇)
2016/11/22 Javascript
Vue中的ref作用详解(实现DOM的联动操作)
2017/08/21 Javascript
实例详解ztree在vue项目中使用并且带有搜索功能
2018/08/24 Javascript
layui实现数据分页功能(ajax异步)
2019/07/27 Javascript
浅谈layui使用模板引擎动态渲染元素要注意的问题
2019/09/14 Javascript
Vue 刷新当前路由的实现代码
2019/09/26 Javascript
js异步接口并发数量控制的方法示例
2020/11/22 Javascript
[06:04]DOTA2英雄梦之声Vol19卓尔游侠
2014/06/20 DOTA
Python MD5文件生成码
2009/01/12 Python
详谈python read readline readlines的区别
2017/09/22 Python
Python3操作SQL Server数据库(实例讲解)
2017/10/21 Python
PyQt4实时显示文本内容GUI的示例
2019/06/14 Python
python经典趣味24点游戏程序设计
2019/07/26 Python
浅谈python 中的 type(), dtype(), astype()的区别
2020/04/09 Python
Django admin管理工具TabularInline类用法详解
2020/05/14 Python
Tensorflow全局设置可见GPU编号操作
2020/06/30 Python
Michael Kors英国官网:美国奢侈品品牌
2019/11/13 全球购物
Java和Javasciprt的区别
2012/09/02 面试题
杭州-DOTNET笔试题集
2013/09/25 面试题
应付会计岗位职责
2013/12/12 职场文书
房地产销售经理岗位职责
2014/01/01 职场文书
金融管理专业毕业生求职信
2014/03/12 职场文书
事业单位竞聘上岗实施方案
2014/03/28 职场文书
项目经理任命书
2014/06/04 职场文书
机械电子工程专业求职信
2014/06/22 职场文书
财产分割协议书范本
2014/11/03 职场文书
Python基础之tkinter图形化界面学习
2021/04/29 Python
MySQL如何解决幻读问题
2021/08/07 MySQL
Java由浅入深通关抽象类与接口(上篇)
2022/04/26 Java/Android