【问题标题】:jQuery event triggered many timesjQuery事件多次触发
【发布时间】:2016-03-14 03:25:46
【问题描述】:

我有一些“复杂”的点击事件,我不知道如何解决它。 我在页面后面添加的一些元素上有一个点击事件,所以我使用了.on

我想要实现的是,当您单击 .neuron 时,您应该无法单击另一个 .neuron,或者您之前单击的那个也不能。这就是我添加.off 函数的原因。

问题是,在打开/关闭神经元 2-3 次后,点击事件会触发 2 次,然后是 4 次,然后是 8 次,以此类推。我不明白为什么。

这里是 jQuery 相关的部分:

$("#nn_container").on("click", ".neuron", zoom_neuron);

function zoom_neuron() {

    $("#nn_container").off("click", ".neuron", zoom_neuron);
    console.log("off");

    /* do some stuff */

    $("#close_neuron").click(function() {
        /* do some stuff */
        $("#nn_container").on("click", ".neuron", zoom_neuron);
        console.log("on");
    });
}

它有什么问题?为什么它在事件调用中持续增加?

【问题讨论】:

  • 你没有解除#close_neuron的点击绑定。

标签: javascript jquery html


【解决方案1】:
$("#nn_container").on("click", ".neuron", zoom_neuron);

function zoom_neuron() {

    $("#nn_container").off("click", ".neuron", zoom_neuron);
    console.log("off");

    /* do some stuff */

    $("#close_neuron").off('click').on('click', (function() {
        /* do some stuff */
        $("#nn_container").on("click", ".neuron", zoom_neuron);
        console.log("on");
    });
}

这将确保#close_neuron 一次只有一个绑定点击事件。这假设代码中没有其他地方将点​​击事件绑定到#close_neuron

【讨论】:

  • 是的!这当然也咬了我好几次!如果对您有用,请随时将问题标记为已回答;)
  • 我当然是。昨天不能,因为我不得不等 9 分钟,然后我在他们之前离开了 :-) 再次感谢!
猜你喜欢
  • 1970-01-01
  • 2022-10-14
  • 2013-02-04
  • 2012-02-26
  • 1970-01-01
  • 1970-01-01
  • 2013-06-14
  • 1970-01-01
相关资源
最近更新 更多