为什么要用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 请求响应乱码
package org.operamasks.servlet; import java.io.IOException; import java.io.PrintWriter; import java. ...
- 单例模式 GetInstance()
如何设计一个含GetInstance()函数的类 直接上代码: 头文件(MyClass.h): class CMyClass { public: CMyClass(void); ~CMyClass(v ...
- SQL Server索引进阶:第十二级,创建,修改,删除
在第十级中我们看到了索引的内部结构,在第十一级中我们看到了平衡树结构潜在的负面影响:索引碎片.有了索引内部结构的知识,我们可以检查在执行数据定义语句和数据操作语句的时候,都发生了什么.在本级中我们介绍 ...
- 前端模块与CMS结合
前端模块与CMS结合 在<FIS官方技术群>经常看到一些讨论,这次是 前端组件化与CMS的相关讨论,主要观点来自群里 漂流瓶(张云龙前辈). CMS是运营人员直接操作,我们往往需求各种各样 ...
- npoi 使用方法
不少朋友在做项目的过程中或多或少的都会用到excel导入.导出功能,下面我来给大家介绍一下使用NPOI如何导入.导出excel, 通过代码描述一下npoi的使用方法,希望都够给需要的朋友一点点帮助,也 ...
- WndProc Msg 消息列表
WM_NULL = 0x0000; WM_CREATE = 0x0001;应用程序创建一个窗口 WM_DESTROY = 0x0002;一个窗口被销毁 WM_MOVE = 0x0003;移动一个窗口 ...
- SqLite 使用 Dapper 查询INTEGER类型的主键问题
在程序实体定义时: public int TableID { get; set; } 使用Dapper查询SqLite数据库时会报错 Error parsing column (= - Int64) ...
- Activity中异步操作showDialog异常解决方法:判断Ay是否结束
Android – Displaying Dialogs From Background Threads 判断一下Activity是否在finishing就好了,否则万一Activity销毁了,这个D ...
- <%=id%>是什么意思
<%=% > 这里可以绑定后台的一个PUBLIC变量 <% % > 如果没有等号 可以在里面写C#语句
- centos下zookeeper集群搭建
单机模式: 1) 首先下载zookeeper压缩包, 这里采用zookeeper3.4.8.... wget http://mirror.bit.edu.cn/apache/zookeeper/zo ...