zoukankan      html  css  js  c++  java
  • jQuery 移除事件

    在绑定事件的过程中,不仅可以为同一个元素绑定多个事件,也可以为多个元素绑定同一个事件。假设网页上有一个<button>元素,使用以下代码为该元素绑定多个相同的事件。

    <script type="text/javascript">
        $(function(){
           $('#btn').bind("click", function(){
                         $('#test').append("<p>我的绑定函数1</p>");
                  }).bind("click", function(){
                         $('#test').append("<p>我的绑定函数2</p>");
                  }).bind("click", function(){
                         $('#test').append("<p>我的绑定函数3</p>");
                  });
        })
    </script>
    
    <body>
    <button id="btn">点击我</button>
    <div id="test"></div>
    </body>

    当单击按钮后,会出现如上图所示的效果。

    1. 移除按钮元素上所有注册的事件

    添加一个移除事件的按钮。然后为按钮绑定一个事件,代码如下:

    <script type="text/javascript">
        $(function(){
           $('#btn').bind("click", function(){
                         $('#test').append("<p>我的绑定函数1</p>");
                  }).bind("click", function(){
                         $('#test').append("<p>我的绑定函数2</p>");
                  }).bind("click", function(){
                         $('#test').append("<p>我的绑定函数3</p>");
                  });
           $('#delAll').click(function(){
                  $('#btn').unbind("click");
           });
        })
    </script>
    
    <body>
    <button id="btn">点击我</button>
    <div id="test"></div>
    <button id="delAll">删除所有事件</button>
    </body>

    因为元素绑定的都是 click 事件,所以不写参数也可以达到同样的目的。

    $('#delAll').click(function(){
      $('#btn').unbind();
    });

    下面来看看 unbind() 方法的语法结构:unbind([type] , [data]);

    第1个参数是事件类型,第2个参数是将要移除的函数,具体说明如下。

    (1) 如果没有参数,则删除所有绑定的事件。

    (2) 如果提供了事件类型作为参数,则只删除该类型的绑定事件。

    (3) 如果把在绑定时传递的处理函数作为第2个参数,则只有这个特定的事件处理函数会被删除。

    2. 移除<button>元素的其中一个事件

    首先需要为这些匿名处理函数指定一个变量。然后就可以单独删除某一个事件了, jQuery 代码如下:

    <script type="text/javascript">
        $(function(){
           $('#btn').bind("click", myFun1 = function(){
                         $('#test').append("<p>我的绑定函数1</p>");
                  }).bind("click", myFun2 = function(){
                         $('#test').append("<p>我的绑定函数2</p>");
                  }).bind("click", myFun3 = function(){
                         $('#test').append("<p>我的绑定函数3</p>");
                  });
           $('#delTwo').click(function(){
                  $('#btn').unbind("click",myFun2);
           });
        })
    </script>
    
    <body>
    <button id="btn">点击我</button>
    <div id="test"></div>
    <button id="delTwo">删除第二个事件</button>
    </body>

    当单击“删除第二个事件”按钮后,再次单击“点击我”按钮,显示下图所示的效果。

    另外,对于只需要触发一次,随后就要立即解除绑定的情况,jQuery 提供了一种简写方法——one() 方法。 one() 方法可以为元素绑定处理函数。当处理函数触发一次后,立即被删除。即在每个对象上,事件处理函数只会被执行一次。

    one() 方法的结构与 bind() 方法类似,使用方法也与 bind() 方法相同,其语法结构如下:one( type, [data], fn );

    示例代码如下:

    <script type="text/javascript">
        $(function(){
           $('#btn').one("click", function(){
                         $('#test').append("<p>我的绑定函数1</p>");
                  }).one("click", function(){
                         $('#test').append("<p>我的绑定函数2</p>");
                  }).one("click", function(){
                         $('#test').append("<p>我的绑定函数3</p>");
                  });
        })
    </script>
    
    <body>
    <button id="btn">点击我</button>
    <div id="test"></div>
    </body>

    使用one() 方法为<button>元素绑定单击事件后,只在用户第1次单击按钮时,处理函数才执行,之后的单击毫无作用。

  • 相关阅读:
    mysql5.7版本centos8环境修改my.cnf配置文件
    mysql5.7使用r2dbc持久层框架性能飙升,一小时插入623万数据,平均每秒插入1723条
    mysql5.7决定SQL中IN条件是否走索引的成本计算,mysql中的index dive是在两个区间之间计算有多少条记录的方式
    mysql5.7的SQL执行成本计算,IO成本和CPU成本,单表查询成本,多表连接查询成本,执行成本决定mysql是否走索引,.OPTIMIZER_TRACE,cost_info
    mysql5.7基于块的嵌套循环连接(Block Nested-Loop Join)
    时间复杂度计算法
    mysql5.7索引合并:交集、并集,EXPLAIN例子
    mysql5.7分区表
    mysql5.7的随机IO和顺序IO
    MySQL5.7二级索引+回表的MRR优化技术
  • 原文地址:https://www.cnblogs.com/jwen1994/p/10568301.html
Copyright © 2011-2022 走看看