如何防止其他事件处理程序,从第一个处理程序,在jQuery

如果将两个或多个事件处理程序附加到HTML元素,它们将会一个一个执行。但是,如果要根据第一个处理程序中检查的条件停止后续事件处理程序,那么应该怎么办?

例如:

<div id='target'>
</div>

<p id='result'>
</p>

如果第一个处理程序被取消,我想取消第二个处理程序。

$(function() {
    var target = $('#target'),result = $('#result');
    target.click(function(e) {
        result.append('first handler<br />');
        // Here I want to cancel all subsequent event handlers
    });
    target.click(function(e) {
        result.append('second handler<br />');
    });
});

你可以看到小提琴here

PS:我知道e.preventDefault()阻止HTML元素的认动作(例如,阻止由于点击链接而发送HTTP GET请求),e.preventPropagation()导致事件被传播到DOM树中的父元素。我也知道,可以使用一个中间变量,在第一个处理程序中将其设置为true,并在后续处理程序中检查它。但我想看看是否有一个更整洁,先进的解决方案这个问题或不。

解决方法

请参见event.stopImmediatePropagation() – http://api.jquery.com/event.stopImmediatePropagation/

根据jQuery api文档,这个方法

Keeps the rest of the handlers from being executed and prevents the event from bubbling up the DOM tree.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


jQuery表单验证提交:前台验证一(图文+视频)
jQuery表单验证提交:前台验证二(图文+视频)
jQuery如何实时监听获取input输入框的值
JQuery怎么判断元素是否存在
jQuery如何实现定时重定向
jquery如何获取复选框选中的值
jQuery如何清空form表单数据
jQuery怎么删除元素节点
JQuery怎么循环输出数组元素
jquery怎么实现点击刷新当前页面
怎么用jquery实现文字左右展开收缩效果
jquery怎么删除html属性
如何用jquery实现图片翻转效果
jquery怎么删除样式属性
jquery如何获取当前元素的位置
如何用jquery实现点击展开收缩效果
jquery怎么实现点击隐藏显示效果
jQuery如何获取当前页面url
jQuery怎么获取鼠标的位置坐标
简洁易懂的jQuery:HTML表单与jQuery