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 相关文章推荐
javascript中的this详解
Dec 08 Javascript
jquery实现点击页面计算点击次数
Jan 23 Javascript
js实现Select列表内容自动滚动效果代码
Aug 20 Javascript
前端实现文件的断点续传(前端文件提交+后端PHP文件接收)
Nov 04 Javascript
easyui中combotree循环获取父节点至根节点并输出路径实现方法
Nov 10 Javascript
jQuery Checkbox 全选 反选的简单实例
Nov 29 Javascript
整理关于Bootstrap警示框的慕课笔记
Mar 29 Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 Javascript
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
layui实现tab的添加拒绝重复的方法
Sep 04 Javascript
使用webpack和rollup打包组件库的方法
Feb 25 Javascript
JavaScript最完整的深浅拷贝实现方式详解
Feb 28 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
Discuz 模板引擎的封装类代码
2008/07/18 PHP
PHP开发框架laravel安装与配置教程
2015/03/13 PHP
laravel在中间件内生成参数并且传递到控制器中的2种姿势
2019/10/15 PHP
仅用[]()+!等符号就足以实现几乎任意Javascript代码
2010/03/01 Javascript
js鼠标左右键 键盘值小结
2010/06/11 Javascript
让jQuery Mobile不显示讨厌loading界面的方法
2014/02/19 Javascript
提高NodeJS中SSL服务的性能
2014/07/15 NodeJs
介绍JavaScript的一个微型模版
2015/06/24 Javascript
jQuery使用$.ajax提交表单完整实例
2015/12/11 Javascript
jQuery实现图片向左向右切换效果的简单实例
2016/05/18 Javascript
用JavaScript动态建立或增加CSS样式表的实现方法
2016/05/20 Javascript
浅谈JSON.stringify()和JOSN.parse()方法的不同
2016/08/29 Javascript
网站申请不到支付宝接口、微信接口,免接口收款实现方式几种解决办法
2016/12/14 Javascript
在js文件中引入(调用)另一个js文件的三种方法
2020/09/11 Javascript
JavaScript 中的执行上下文和执行栈实例讲解
2021/02/25 Javascript
[00:12]DAC2018 Miracle-站上中单舞台,他能否再写奇迹?
2018/04/06 DOTA
python从ftp下载数据保存实例
2013/11/20 Python
Windows8下安装Python的BeautifulSoup
2015/01/22 Python
python简单获取本机计算机名和IP地址的方法
2015/06/03 Python
浅谈python3.6的tkinter运行问题
2019/02/22 Python
python opencv 实现对图像边缘扩充
2020/01/19 Python
在Windows上安装和配置 Jupyter Lab 作为桌面级应用程序教程
2020/04/22 Python
python切割图片的示例
2020/11/12 Python
Html5 audio标签样式的修改
2016/01/28 HTML / CSS
葡萄牙航空官方网站:TAP Air Portugal
2019/10/31 全球购物
Marc O’Polo俄罗斯官方在线商店:德国高端时尚品牌
2019/12/26 全球购物
应届生自荐信范文
2014/02/21 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
产品售后服务承诺书
2014/05/21 职场文书
小学校园文化建设汇报材料
2014/08/19 职场文书
2015年社区综治工作总结
2015/04/21 职场文书
2016年国庆节假期旅游工作总结
2016/04/01 职场文书
python实现ROA算子边缘检测算法
2021/04/05 Python
Python内置包对JSON文件数据进行编码和解码
2022/04/12 Python
MySQL 语句执行顺序举例解析
2022/06/05 MySQL
教你使用RustDesk 搭建一个自己的远程桌面中继服务器
2022/08/14 Servers