jQuery新的事件绑定机制on()示例应用-阿里云开发者社区

开发者社区> thinkyoung> 正文

jQuery新的事件绑定机制on()示例应用

简介: 投稿:whsnow 字体:[增加 减小] 类型:转载   从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定,下面通过示例为大家介绍下     今天浏览jQuery的deprecated列表,发现live()和die()在里面了,赶紧看了一下,发现从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定。
+关注继续查看

 

投稿:whsnow 字体:[增加 减小] 类型:转载
 
从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定,下面通过示例为大家介绍下
 
 

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

1
2
3
$('#list li').live('click', '#list li', function() {
//function code here.
});

on()写法

1
2
3
$(document).on('click', '#list li', function() {
//function code here.
});

这里的关键就是第二个参数'selector'在起作用了。它是一个过滤器的作用,只有被选中元素的后代元素才会触发事件。

替换delegate()
delegate()是1.4引入的,目的是通过祖先元素来代理委派后代元素的事件绑定问题,某种程度上和live()优点相似。只不过live()是通过document元素委派,而delegate则可以是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。

delegate()的写法

1
2
3
$('#list').delegate('li', 'click', function() {
//function code here.
});

on()写法 

1
2
3
$('#list').on('click', 'li', function() {
//function code here.
});


貌似第一个和第二个参数的顺序颠倒了一下,别的基本一样。

总结

jQuery推出on()的目的有2个,一是为了统一接口,二是为了提高性能,所以从现在开始用on()替换bind(), live(), delegate吧。尤其是不要再用live()了,因为它已经处于不推荐使用列表了,随时会被干掉。如果只绑定一次事件,那接着用one()吧,这个没有变化。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SAP Spartacus Multi-Site Configuration
SAP Spartacus Multi-Site Configuration
5 0
SAP Spartacus CMSService 的调用栈以及 meta 标签的生成过程
SAP Spartacus CMSService 的调用栈以及 meta 标签的生成过程
4 0
调试 SAP Spartacus 服务器端渲染 SEO HTML Tag 生成逻辑的注意事项
调试 SAP Spartacus 服务器端渲染 SEO HTML Tag 生成逻辑的注意事项
3 0
SAP Spartacus 成功登录之后,请求 base site 到底需不需要 Access Token
SAP Spartacus 成功登录之后,请求 base site 到底需不需要 Access Token
6 0
SAP Spartacus package.json 里定义的 ts-loader
SAP Spartacus package.json 里定义的 ts-loader
7 0
将您的基于 Accelerator 的 SAP Commerce Cloud Storefront 迁移到 Spartacus Storefront
将您的基于 Accelerator 的 SAP Commerce Cloud Storefront 迁移到 Spartacus Storefront
1 0
SAP Spartacus 服务器端渲染模式下,在 Node.js 服务器端渲染视图的单步调试
SAP Spartacus 服务器端渲染模式下,在 Node.js 服务器端渲染视图的单步调试
5 0
选择 SAP Spartacus 作为 SAP Commerce Cloud Storefront 实现框架的五个理由
选择 SAP Spartacus 作为 SAP Commerce Cloud Storefront 实现框架的五个理由
1 0
Angular 事件绑定语法在 SAP Spartacus Popover Component 中的一个应用
Angular 事件绑定语法在 SAP Spartacus Popover Component 中的一个应用
7 0
如何给 SAP Spartacus cxOutletPos 赋值
如何给 SAP Spartacus cxOutletPos 赋值
1 0
+关注
509
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载