zoukankan      html  css  js  c++  java
  • jQuery 嵌套 event 会触发多次的原因

    Html代码如下:

    <div id="cover">
      <input type="button" id="inside" value="submit_inside" />
    </div>
    <div id="cover_js">
       <input type="button" id="inside_js" value="submit_inside_js" />
    </div>
    <input type="button" id="outside" value="submit_outside" />

    jQuery代码如下:

    $('#cover').mouseover(function () {
      $('#inside').click(function () {
        alert('multiple times');
      });    
    });
    
    $('#cover_js').mouseover(function () {
      document.getElementById('inside_js').onclick = function () {
        alert('just one time');
      }    
    });
    
    $('#outside').click(function () {
      alert('just one time');
    });

    id 为 inside 的按钮的 click 事件被嵌套在 div 的鼠标事件内,而 id 为 outside 的按钮则未嵌套,分别对两个按钮进行多次点击后,inside 按钮绑定的 click 事件会进行累加,而 outside 按钮则仍旧只绑定一个 click 事件。id 为 inside_js 的按钮的 click 事件也被嵌套在 div 的鼠标事件内,但是我用 javascript 实现 click,此时点击多次后,只触发一个 alert。
    解决上述问题可以用 unbind 对嵌套 event 进行解绑:

    $('#cover').mouseover(function () {
      $('#inside').off.('click').click(function () {
        alert('multiple times');
      });    
    });

    原因:

    jQuery所有的事件(.click.mouseover.hover 等等)都是通过on =>  event.add  =>  addEventListener,来实现的。

    代码每次mouseover的时候就多绑定了一次事件回调。
    原生的onclick每次赋值都直接覆盖了之前的onclick绑定,所以不推荐这样写。
    若是用原生的addEventListener也会得到跟jQuery一样的结果。

  • 相关阅读:
    【Python web 开发】购物车功能需求分析和加入购物车功能实现
    【Python web 开发】第九章开发总结
    【Python web 开发】个人中心-用户的收货地址
    【Python web 开发】个人中心-用户留言功能
    自适应网页设计(Responsive Web Design)
    无废话MVC系列教程
    标准查询运算符
    系统泛型委托
    var隐式类型
    自动属性
  • 原文地址:https://www.cnblogs.com/gxp69/p/7262679.html
Copyright © 2011-2022 走看看