jQuery事件多次绑定与解绑问题实例分析


Posted in jQuery onFebruary 19, 2019

本文实例分析了jQuery事件多次绑定与解绑问题。分享给大家供大家参考,具体如下:

jQuery事件绑定很常见,相信大家经常会用到clickfocusblur等事件,但是如果对控件的某个事件绑定多个方法会是怎样的结果呢,覆盖、累加、或其他效果?今天我就来验证一下这个疑问并说说如何解绑。

一、jQuery事件多次绑定

<head>
  <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  <script type="text/javascript">
    $(document).ready(function () {
      //第二次绑定
      $("#btnAdd").click(function () {
        alert("bind click1");
      });
      //第三次绑定
      $("#btnAdd").on("click", function () {
        alert("bind click2");
      });
      //第四次绑定
      $("#btnAdd").bind("click", function () {
        alert("bind click3");
      });
    });
    function add1() {
      alert("add1()");
    }
  </script>
</head>
<body>
  <h2>UserController->Index</h2>
  <!--第一次绑定-->
  <input type="button" id="btnAdd" name="btnAdd" value="Add" onclick="add1()" />
</body>

验证结果:对控件的某个事件进行多次绑定效果会叠加,截图如下:

jQuery事件多次绑定与解绑问题实例分析

二、jQuery事件解绑

既然能绑定事件,那应该也能对事件解绑,下面展示解绑的方法:

<head>
  <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  <script type="text/javascript">
    $(document).ready(function () {
      $("#btnAdd").click(function () {
        alert("bind click1");
      });
      $("#btnAdd").on("click", add2);
      $("#btnAdd").bind("click", add3);
    });
    function add1() {
      alert("add1()");
    }
    function add2() {
      alert("bind click2");
    }
    function add3() {
      alert("bind click3");
    }
    function cancelBind() {
      //不指定方法名则解绑click事件对应的所有方法,标签内onclick设置的方法仍会执行
      //$("#btnAdd").off("click");
      //$("#btnAdd").unbind("click");
      //解绑click事件对应的add2方法
      $("#btnAdd").off("click", add2);
      //$("#btnAdd").unbind("click", add3);
    }
  </script>
</head>
<body>
  <h2>UserController->CancelBind</h2>
  <input type="button" id="btnAdd" name="btnAdd" value="Add" onclick="add1()" />
  <input type="button" id="btnCancelBind" name="btnCancelBind" value="CancelBind" onclick="cancelBind()" />
</body>

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家jQuery程序设计有所帮助。

jQuery 相关文章推荐
jQuery Ajax使用FormData上传文件和其他数据后端web.py获取
Jun 11 jQuery
jQuery+C#实现参数RSA加密传输功能【附jsencrypt.js下载】
Jun 26 jQuery
jQuery扩展_动力节点Java学院整理
Jul 05 jQuery
jQuery Collapse1.1.0折叠插件简单使用
Aug 28 jQuery
jquery radio 动态控制选中失效问题的解决方法
Feb 28 jQuery
jQuery实现的点击标题文字切换字体效果示例【测试可用】
Apr 26 jQuery
jQuery.extend 与 jQuery.fn.extend的用法及区别实例分析
Jul 25 jQuery
详解如何使用webpack打包多页jquery项目
Feb 01 jQuery
jquery 键盘事件 keypress() keydown() keyup()用法总结
Oct 23 jQuery
jQuery实现全选、反选和不选功能的方法详解
Dec 04 jQuery
jquery实现点击弹出对话框
Feb 08 jQuery
jQuery带控制按钮轮播图插件
Jul 31 jQuery
JS/jQuery实现简单的开关灯效果【案例】
Feb 19 #jQuery
jQuery AJAX与jQuery事件的分析讲解
Feb 18 #jQuery
jQuery实现的卷帘门滑入滑出效果【案例】
Feb 18 #jQuery
jQuery插件实现非常实用的tab栏切换功能【案例】
Feb 18 #jQuery
jQuery实现的五星点评功能【案例】
Feb 18 #jQuery
jQuery实现的隔行变色功能【案例】
Feb 18 #jQuery
jQuery实现ajax的嵌套请求案例分析
Feb 16 #jQuery
You might like
php array_pop()数组函数将数组最后一个单元弹出(出栈)
2011/07/12 PHP
单点登录 Ucenter示例分析
2013/10/29 PHP
php实现约瑟夫问题的方法小结
2015/03/23 PHP
PHP新建类问题分析及解决思路
2015/11/19 PHP
html 锁定页面(js遮罩层弹出div效果)
2009/10/27 Javascript
jqTransform form表单美化插件使用方法
2012/07/05 Javascript
jQuery实现数字加减效果汇总
2014/12/16 Javascript
js实现的捐赠管理完整实例
2015/01/20 Javascript
JQuery中clone方法复制节点
2015/05/18 Javascript
JQ技术实现注册页面带有校验密码强度
2015/07/27 Javascript
ECMAScript6轮播图实践知识总结
2016/08/17 Javascript
使用bootstrapValidator插件进行动态添加表单元素并校验
2016/09/28 Javascript
Vue.js仿Metronic高级表格(一)静态设计
2017/04/17 Javascript
20行JS代码实现网页刮刮乐效果
2017/06/23 Javascript
浅谈JS中的常用选择器及属性、方法的调用
2017/07/28 Javascript
AngularJS 实现购物车全选反选功能
2017/10/24 Javascript
js实现经典贪吃蛇小游戏
2020/03/19 Javascript
vue axios封装httpjs,接口公用配置拦截操作
2020/08/11 Javascript
js canvas实现五子棋小游戏
2021/01/22 Javascript
js闭包和垃圾回收机制示例详解
2021/03/01 Javascript
python计算最大优先级队列实例
2013/12/18 Python
利用Python脚本生成sitemap.xml的实现方法
2017/01/31 Python
python 寻找list中最大元素对应的索引方法
2018/06/28 Python
详解pyenv下使用python matplotlib模块的问题解决
2018/11/29 Python
Tensorflow中的dropout的使用方法
2020/03/13 Python
Python selenium环境搭建实现过程解析
2020/09/08 Python
英国二手iPhone、音乐、电影和游戏商店:musicMagpie
2018/10/26 全球购物
人事档案接收函
2014/01/12 职场文书
最经典的大学生职业生涯规划范文
2014/03/05 职场文书
珠宝店促销方案
2014/03/21 职场文书
学校运动会广播稿范文
2014/10/02 职场文书
小马王观后感
2015/06/11 职场文书
好段摘抄大全(48句)
2019/08/08 职场文书
js基础语法与maven项目配置教程案例
2021/07/15 Javascript
MySQL实战记录之如何快速定位慢SQL
2022/03/23 MySQL
Python进程池与进程锁之语法学习
2022/04/11 Python