jQuery中用on绑定事件时需注意的事项


Posted in Javascript onMarch 19, 2017

随着jQuery版本的更新,以前版本的Bind(),live(),delegate()事件可以直接被on代替,本次笔记仅以点击事件为例,主要考察了on事件的用法:

一、用on监听点击事件前添加的DOM,可以正常触发:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style type="text/css">
 #test {
 height: 100px;
 font-size: 50px;
 color: yellow;
 line-height: 100px;
 background-color: red;
 text-align: center;
 }
</style>
<script src="http://lib.sinaapp.com/js/jquery/2.0.2/jquery-2.0.2.min.js"></script>
<script>
 $( function(){
 var oDiv = $('<div id="test">点我</div>');
 $(document.body).append(oDiv);
 $("#test").on('click', function(){
 alert('这是事件前添加的DOM,可以正常触发点击事件');
 });
 } );
</script>
</head>
<body>
 <div id="wrap"></div>
</body>
</html>

二、用on监听点击事件后添加的DOM,无法正常触发:

<!-- 一、正常的DOM: -->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style type="text/css">
 #test {
 height: 100px;
 font-size: 50px;
 color: yellow;
 line-height: 100px;
 background-color: red;
 text-align: center;
 }
</style>
<script src="http://lib.sinaapp.com/js/jquery/2.0.2/jquery-2.0.2.min.js"></script>
<script>
 $( function(){
 $("#test").on('click', function(){
 alert('这是事件后添加的DOM,无法正常触发点击事件');
 });
 var oDiv = $('<div id="test">点我</div>');
 $(document.body).append(oDiv);
 } );
</script>
</head>
<body>
 <div id="wrap"></div>
</body>
</html>

三、解决办法:利用事件委托。需要注意的是:委托的对象必须是DOM中已经存在或者事件前动态添加,此时,用on监听后后可以正常触发事件,否则如:步骤四:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style type="text/css">
 #test {
 height: 100px;
 font-size: 50px;
 color: yellow;
 line-height: 100px;
 background-color: red;
 text-align: center;
 }
</style>
<script src="http://lib.sinaapp.com/js/jquery/2.0.2/jquery-2.0.2.min.js"></script>
<script>
 $( function(){
 var oWrap = $('<div id="wrap"></div>');
 $(document.body).append(oWrap);
 $("#wrap").on('click', $('#test'), function(){
 alert('委托对象在事件前添加,可以正常触发点击事件');
 });
 var oDiv = $('<div id="test">点我</div>');
 $("#wrap").append(oDiv);
 } );
</script>
</head>
<body>
</body>
</html>

四、委托对象在事件后添加,无法触发点击事件

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style type="text/css">
 #test {
 height: 100px;
 font-size: 50px;
 color: yellow;
 line-height: 100px;
 background-color: red;
 text-align: center;
 }
</style>
<script src="http://lib.sinaapp.com/js/jquery/2.0.2/jquery-2.0.2.min.js"></script>
<script>
 $( function(){
 $("#wrap").on('click', $('#test'), function(){
 alert('委托对象在事件后添加,无法正常触发点击事件');
 });
 var oWrap = $('<div id="wrap"></div>');
 $(document.body).append(oWrap);
 var oDiv = $('<div id="test">点我</div>');
 $("#wrap").append(oDiv);
 } );
</script>
</head>
<body>
</body>
</html>

五、说明:工作中,on事件比较常用的还是事件绑定和事件委托,至少我碰到的比较多,live事件on用法主要是前面的jQuery对象变成了document,如:$(document).on(),故不另作举例。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript 获取网页参数系统
Jul 19 Javascript
在WordPress中加入Google搜索功能的简单步骤讲解
Jan 04 Javascript
Jquery实现遮罩层的简单实例(就是弹出DIV周围都灰色不能操作)
Jul 14 Javascript
Javascript中数组去重与拍平的方法示例
Feb 03 Javascript
javascript中mouseenter与mouseover的异同
Jun 06 Javascript
JS+HTML5 FileReader实现文件上传前本地预览功能
Mar 27 Javascript
深入理解requireJS-实现一个简单的模块加载器
Jan 15 Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
Feb 23 Javascript
vue使用ajax获取后台数据进行显示的示例
Aug 09 Javascript
JavaScript实现轮播图效果代码实例
Sep 28 Javascript
如何在postman中添加cookie信息步骤解析
Jun 30 Javascript
uniapp开发小程序的经验总结
Apr 08 Javascript
$.browser.msie 为空或不是对象问题的多种解决方法
Mar 19 #Javascript
JavaScript数据结构之链表的实现
Mar 19 #Javascript
用jQuery实现圆点图片轮播效果
Mar 19 #Javascript
Bootstrap 网格系统布局详解
Mar 19 #Javascript
用JavaScript和jQuery实现瀑布流
Mar 19 #Javascript
JSONP基础知识详解
Mar 19 #Javascript
jQuery中table数据的值拷贝和拆分
Mar 19 #Javascript
You might like
PHPWind与Discuz截取字符函数substrs与cutstr性能比较
2011/12/05 PHP
PHP制作万年历
2015/01/07 PHP
php+ajax无刷新上传图片的实现方法
2016/12/06 PHP
PHP等比例压缩图片的实例代码
2018/07/26 PHP
PHP操作路由器实现方法示例
2019/04/27 PHP
thinkphp5 模型实例化获得数据对象的教程
2019/10/18 PHP
jQuery实现的类flash菜单效果代码
2010/05/17 Javascript
JavaScript Date对象 日期获取函数
2010/12/19 Javascript
div模拟滚动条效果示例代码
2013/10/16 Javascript
jquery ajax 简单范例(界面+后台)
2013/11/19 Javascript
window.returnValue使用方法示例介绍
2014/07/03 Javascript
JavaScript使用Replace进行字符串替换的方法
2015/04/14 Javascript
js剪切板应用clipboardData实例解析
2016/05/29 Javascript
js 定义对象数组(结合)多维数组方法
2016/07/27 Javascript
javascript深拷贝(deepClone)详解
2016/08/24 Javascript
AngularJS过滤器filter用法总结
2016/12/13 Javascript
js实现登录验证码
2016/12/22 Javascript
Angular2里获取(input file)上传文件的内容的方法
2017/09/05 Javascript
JS中常用的消息框总结
2018/02/24 Javascript
原生JS实现动态加载js文件并在加载成功后执行回调函数的方法
2020/12/30 Javascript
jQuery zTree树插件的使用教程
2019/08/16 jQuery
微信小程序基于movable-view实现滑动删除效果
2020/01/08 Javascript
Jquery高级应用Deferred对象原理及使用实例
2020/05/28 jQuery
Python实现冒泡,插入,选择排序简单实例
2014/08/18 Python
python中OrderedDict的使用方法详解
2017/05/05 Python
python的staticmethod与classmethod实现实例代码
2018/02/11 Python
在matplotlib的图中设置中文标签的方法
2018/12/13 Python
windows 10 设定计划任务自动执行 python 脚本的方法
2019/09/11 Python
python机器学习实现决策树
2019/11/11 Python
Python3打包exe代码2种方法实例解析
2020/02/17 Python
Django使用rest_framework写出API
2020/05/21 Python
Python 实现集合Set的示例
2020/12/21 Python
CSS3中background-clip和background-origin的区别示例介绍
2014/03/10 HTML / CSS
微软澳洲官方网站:Microsoft Australia
2017/01/10 全球购物
资料员的岗位职责
2013/11/20 职场文书
阿里云服务器Ubuntu 20.04上安装Odoo 15
2022/05/20 Servers