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 相关文章推荐
jquery radio 操作代码
Mar 16 Javascript
JS定义回车事件(实现代码)
Jul 08 Javascript
javascript正则表达式之search()用法实例
Jan 19 Javascript
js禁止页面刷新与后退的方法
Jun 08 Javascript
Vue2.x中的父组件传递数据至子组件的方法
May 01 Javascript
详解jQuery中的isPlainObject()使用方法
Feb 27 jQuery
基于Bootstrap下拉框插件bootstrap-select使用方法详解
Aug 07 Javascript
微信小程序单选radio及多选checkbox按钮用法示例
Apr 30 Javascript
微信小程序HTTP请求从0到1封装
Sep 09 Javascript
深入理解javascript prototype的相关知识
Sep 19 Javascript
Vue项目开发常见问题和解决方案总结
Sep 11 Javascript
vue-calendar-component 封装多日期选择组件的实例代码
Dec 04 Vue.js
$.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
SONY SRF-40W电路分析
2021/03/02 无线电
php版微信自动获取收货地址api用法示例
2016/09/22 PHP
PHP环形链表实现方法示例
2017/09/15 PHP
用JavaScript事件串连执行多个处理过程的方法
2007/03/09 Javascript
用jquery实现学校的校历(asp.net+jquery ui 1.72)
2010/01/01 Javascript
javascript学习笔记(九) js对象 设计模式
2012/06/19 Javascript
javascript获取设置div的高度和宽度兼容任何浏览器
2013/09/22 Javascript
可自定义速度的js图片无缝滚动示例分享
2014/01/20 Javascript
Javascript中设置默认参数值示例
2014/09/11 Javascript
jQuery实现的自动加载页面功能示例
2016/09/04 Javascript
React-router v4 路由配置方法小结
2017/08/08 Javascript
js异步编程小技巧详解
2017/08/14 Javascript
微信小程序使用slider设置数据值及switch开关组件功能【附源码下载】
2017/12/09 Javascript
vue项目引入字体.ttf的方法
2018/09/28 Javascript
微信小程序项目总结之记账小程序功能的实现(包括后端)
2019/08/20 Javascript
微信小程序实现点击卡片 翻转效果
2019/09/04 Javascript
Vue关于组件化开发知识点详解
2020/05/13 Javascript
Node.js中的异步生成器与异步迭代详解
2021/01/31 Javascript
python 接口返回的json字符串实例
2018/03/27 Python
flask 框架操作MySQL数据库简单示例
2020/02/02 Python
python属于解释型语言么
2020/06/15 Python
matplotlib 三维图表绘制方法简介
2020/09/20 Python
西尔斯百货官网:Sears
2016/09/06 全球购物
马来西亚在线购物市场:PGMall.my
2019/10/13 全球购物
美国职棒大联盟的官方手套、球和头盔:Rawlings
2020/02/15 全球购物
六十大寿答谢词
2014/01/12 职场文书
企业管理培训感言
2014/01/27 职场文书
驾驶员岗位职责
2014/01/29 职场文书
机关党总支领导班子整改方案
2014/09/20 职场文书
2014年幼儿园个人工作总结
2014/11/10 职场文书
从事会计工作年限证明
2015/06/23 职场文书
2019年思想汇报
2019/06/20 职场文书
pytorch 如何使用amp进行混合精度训练
2021/05/24 Python
Python采集股票数据并制作可视化柱状图
2022/04/04 Python
mysql数据库隔离级别详解
2022/06/16 MySQL
MutationObserver在页面水印实现起到的作用详解
2022/07/07 Javascript