首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >阻止事件在DOM中冒泡

阻止事件在DOM中冒泡
EN

Stack Overflow用户
提问于 2015-03-27 17:11:31
回答 1查看 65关注 0票数 1

我正在写一个HTML编辑器,任何人都可以将这个插件插入到他们的站点中并使用它。

插件使用

代码语言:javascript
复制
$(".editable").htmleditor();

单击此元素,我将将元素更改为contenteditable,我的编辑器菜单将在元素附近打开,就像aloha一样。

问题

场景1

代码语言:javascript
复制
<div class='editable' onclick='loadUrl('https://facebook.com')'>
</div>

场景2

代码语言:javascript
复制
<div class='editable' id='openNewWindow'></div>
<script>
    $("#openNewWindow").click(function(e){
        e.preventDefault();
        e.stopPropagation();
    });
</script>

前面提到的场景我不会收到这个事件。这使得我的插件不可靠。我尝试了几种解决方案。

解决方案我试过

  1. 删除主体中的所有元素,并再次插入其中以删除附加的事件处理程序。它可以工作,但用户界面是扭曲的,同时插入一些网站。
  2. 在所有元素中添加了onclick='return false'属性。它只适用于某些元素。

如何解除所有附加事件处理程序的绑定并防止元素的默认事件?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-27 17:47:37

在场景1中,插件的用户既使元素可编辑,又使单击它可以从当前页面导航。这没什么意义,但这是他们的事。在这种情况下,他们不能现实地期望您的插件运行。

在场景2中,您需要在其他地方处理click事件之前处理它。删除或抑制现有的处理程序不是一个好主意:它可能会使页面的其他部分失败,并且在任何情况下都会使用户感到厌烦。

相反,您可以让处理程序在事件捕获阶段运行,如下所示:

代码语言:javascript
复制
editableElement.addEventLister("click", myHandler, true); // note the "true"

现在,您的处理程序将在使用JQuery添加的所有处理程序之前运行(以及大多数人通过任何方式添加的处理程序),这些处理程序在事件气泡阶段运行。请注意,这种技术只适用于现代浏览器(即,IE < 9)。

参考:What is event bubbling and capturing?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29306358

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档