为什么要用on()而不直接使用click
为什么要用on()而不直接使用click
http://stackoverflow.com/questions/10082031/why-use-jquery-on-instead-of-click
http://stackoverflow.com/questions/8110934/direct-vs-delegated-jquery-on
有两个好处 使用on()可以为动态生成的元素绑定事件
其次 使用on可以只为父元素绑定事件 不需要为子元素都一个一个的绑定
首先需要明白 并不是说动态生成的元素就一定不能用.click的方式来绑定事件
(否则逻辑上说不通 对吧)
在使用$('.xxx').click的时候 只要$('.xxx')可以得到元素 就可以绑定
只是你需要特别注意执行顺序 使用$('.xxx') 之前 .xxx这个元素已经在DOM中
是不是使用 $('.xxx').on 就可以不用注意呢?也不是 要不然$('.xxx')的到的是undefined怎么可能绑定事件呢
这样子写两者是完全等价的
$(".close-box").click( function() {
MoneyBox.closeBox();
return false;
});
$(".close-box").on("click", function () {
MoneyBox.closeBox();
return false;
});
那应该如何用on()呢?
$('#container').on('click', '.elementClass', function() {
});
其中 #container 是 .elementClass的前辈 且最好保证是静态的元素,否则还是要注意绑定的时机...
这样在click #container中的.elementClass元素就可以执行对应的处理了\
想要取消事件? 使用off()
http://www.andismith.com/blog/2011/11/on-and-off/
==============这是之前写的===================
都说on是用于动态添加的元素的事件。但是你不觉得奇怪嘛,难道动态添加的元素就不能用普通的事件绑定,这样说不通啊!
其实是on可以在元素添加到dom之前绑定,而对于普通绑定,只要元素已经出现在了dom中,不论是否动态添加 事件当然也是生效的

$('body').on('click', '.d1', function(event) {
//event.preventDefault();
console.log('on0');//ok
});
console.log($('.d1'));
$('.d1').on('click', function(event) {
console.log('on1'); //not working becasuse $('.d1') is undefined
});
$('.d1').click(function(event) {
/* Act on the event */
console.log('click0');// not working same reason as before
});
var dq=$('<div class="d1"></div>');
$('body').append(dq);
$('.d1').click(function(event) {
/* Act on the event */
console.log('click');
});

可以看到 对于on 绑定也是有要求的,如果on的左边的对象不存在 当然绑定也是不行的。
on左边应该是一个已经存在的父元素,待绑定click对象是d1 这样就是在元素添加到DOM之前指定了事件处理
为什么要用on()而不直接使用click的更多相关文章
- zepto的touch模块解决click延迟300ms问题以及点透问题的详解
大家都知道移动端的click事件会延迟300ms触发,这时大家可以使用zepto的touch模块,里面定义了一个tap事件,通过绑定tap事件,可以实现点击立即触发的功能. 那么,它的tap事件是怎么 ...
- click与on的区别
click只能用于html在注册事件之后没有变化的:on用于html在注册事件后,还会通过JS脚本添加一些按钮,并者希望这些按钮也会有之前注册事件的按钮同样的事件话,就需要用on去为按钮的父节点去注册 ...
- 移动Web触控事件总结
移动web风风火火几多年,让我这个在Pc端漂流的前端er不免心生仰慕,的确入行几多年,也该是时候进军移动web了.移动web中踩到的第一个坑就是事件问题,所以在吸取众大神的经验后,特作总结以示后来者. ...
- Element.Event
addEvent(type,fn):为DOM元素增加一个事件监听器 removeEvent(type,fn):移除先前为DOM元素添加的事件监听器 eg: var destroy = function ...
- 移动端300ms点击事件的延迟
移动端click事件300ms延迟 移动端click事件300ms的延迟在目前看来,已经是老生常谈了. 以下内容,我会在参考资源的基础上谈谈我对移动端click事件300ms延迟的一些理解.本人愚昧, ...
- HTML和CSS使用注意事项
HTML 1.button标签 在IE中,button标签默认的type是button,而在其他浏览器和W3C标准中button默认的属性都是submit. 所以,在一个form表单中,如果butto ...
- 2017-11-20 中文代码示例之Vuejs入门教程(一)问题后续
"中文编程"知乎专栏原文 第一个issue: Error compiling template if using unicode naming as v-for alias · I ...
- react.js学习之路四
针对学习react.js中,我感觉最大的疑惑点就是bind(this)的绑定和指向问题了,我被这个问题弄的头昏,有时候调用组件的时候,直接显示undefined,不存在这个组件,当时的心情是崩溃的,整 ...
- Web前端——JavaScript扩展补充
JS补充 document也是windows的一个子对象 a标签点击事件 要想设置点击a标签,执行某种方法,推荐在a标签的herf属性使用JavaScript伪协议,实现点击之后执行的js方法,而不是 ...
随机推荐
- java调试工具
jps当前用户已启动的java进程信息,信息包括进程号和简短的进程command. jstat输出指定 jvm 实例的特定统计量:统计量:-class-compiler-gc-gccapacity-g ...
- Git - 常用技能
参考: http://wuchong.me/blog/2015/03/30/git-useful-skills/
- linux php文件include失败 一个很神奇的问题
1. html生成失败,权限问题 前天用php生成模板,在windows上开发,include文件,读缓存写文件,顺风顺水,晚上写完后传到linux上html生成失败,发现文件和文件夹都没生成,网上查 ...
- BZOJ 1812: [Ioi2005]riv( 树形dp )
树背包, 左儿子右兄弟来表示树, dp(x, y, z)表示结点x, x的子树及x的部分兄弟共建y个伐木场, 离x最近的伐木场是z时的最小代价. 时间复杂度O(N^2*K^2) ----------- ...
- Hibernate学习之检索策略
一.类级别的检索策略 类级别可选的检索策略包括立即检索和延迟检索, 默认为延迟检索 –立即检索: 立即加载检索方法指定的对象 –延迟检索: 延迟加载检索方法指定的对象,在使用具体的属性时,再进行加载 ...
- Servlet基础知识(一)——Servlet的本质
什么是Servlet: Servlet是运行在web服务器端(web容器,如tomcat)的程序,它与Applet相对,Applet是运行在客户端的程序. Servlet的主要作用是处理客户端的请求, ...
- 网络技术教程笔记(20)ISDN
广域网与接入网技术 广域网与接入网技术 常见接入技术--ISDN 综合业务数字网(Integrated Services Digital Network,ISDN)由电话综合数字网IDN演化而成,能够 ...
- jquery实现锚点动画效果
锚点相信大家都使用过吧!点击后僵硬的切换是不是很不爽呢? 下面分享一个小技巧,根据锚点offset值来实现动画切换 <!DOCTYPE html PUBLIC "-//W3C//DTD ...
- Unity 4.2.0 官方最新破解版(Unity3D 最新破解版,3D游戏开发工具和游戏引擎套件)
Unity是一款跨平台的游戏开发工具,从一开始就被设计成易于使用的产品.作为一个完全集成的专业级应用,Unity还包含了价值数百万美元的功能强大的游戏引擎.Unity作为一个游戏开发工具,它的设计主旨 ...
- halcon与C#混合编程进阶版
这篇主要是C#和Halcon的混合编程,在此基础上对按键不同功能的划分,以及图片适应窗口和从本地打开图片. 新手来这里:http://www.cnblogs.com/badguy518/p/55150 ...