为什么要用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方法,而不是 ...
随机推荐
- (转)MapReduce 中的两表 join 几种方案简介
1. 概述 在传统数据库(如:MYSQL)中,JOIN操作是非常常见且非常耗时的.而在HADOOP中进行JOIN操作,同样常见且耗时,由于Hadoop的独特设计思想,当进行JOIN操作时,有一些特殊的 ...
- Netty之ChannelOption
一.概述 最近在写一个分布式服务框架,打算用netty框架做底层网络通信,关于netty的学习可以参考如下资料: http://blog.csdn.net/column/details/enjoyne ...
- IOS基础:深入理解Objective-c中@class的含义
objective-c中,当一个类使用到另一个类时,并且在类的头文件中需要创建被引用的指针时, 如下面代码: A.h文件 #import "B.h" @interface A : ...
- Struts学习之流程汇总
struts2 架构图如下图所示: 依照上图,我们可以看出一个请求在struts的处理大概有如下步骤: 1.客户端初始化一个指向Servlet容器(例如Tomcat)的请求: 2.这个请求经过一系列的 ...
- MySQL 基础学习
http://www.w3school.com.cn/sql/ 1.limit x,y 或 limit z :选取从x开始的y条数据 或 选取最开始的 z条数据 , 2.like '%N%' : ...
- 【转】CentOS 使用yum命令安装出现错误提示”could not retrieve mirrorlist http://mirrorlist.centos.org ***”
源自:http://www.cnblogs.com/yangbingqi/p/3328610.html 刚安装完CentOS,使用yum命令安装一些常用的软件,使用如下命令:yum grouplist ...
- Cortex-M3动态加载三(模块调用系统函数)
在我的arm动态加载实验中需要解决一个模块调用系统函数的问题,可以使用以下的一个方法.将系统函数固定在某一段地址空间,然后导出这一块的符号表到符号文件中,要记载的模块link的时候使用这个符号表文件, ...
- Hadoop基准测试(转载)
<hadoop the definitive way>(third version)中的Benchmarking a Hadoop Cluster Test Cases的class在新的版 ...
- PullToRrefresh自定义下拉刷新动画
首先,下载著名的刷新框架https://github.com/chrisbanes/Android-PullToRefresh,其中simple为demo,library和extras作为项目包导入到 ...
- Javascript 风格向导
序 大部分针对Javascript最合理的方法归纳. 类型 • 原始类型:我们可以直接使用值. ο string ο number ο boolean ο null ο undefined ...