首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >防止Vue中的事件冒泡

防止Vue中的事件冒泡
EN

Stack Overflow用户
提问于 2018-02-15 00:04:09
回答 5查看 60K关注 0票数 68
代码语言:javascript
复制
<div id="largeArea" v-on:click="do_X">
    <button>Button</button>
</div>

因此,我在Vue中有一个问题,我不想在单击按钮时触发"do_X“,尽管它是largeArea的一部分。

EN

Stack Overflow用户

发布于 2021-05-23 14:51:24

我正在创建一个导航栏,并有类似的要求。我希望弹出菜单在点击任何地方时关闭,接受菜单或其子菜单。

这可以通过使用事件修饰符来完成。在参考之前请参阅此文档

具体来说,我们可以使用stop事件修饰符。

代码语言:javascript
复制
<div id="largeArea" v-on:click="do_X()">
    <button @click.stop="">Button</button>
</div>

.stop将停止事件传播。

在我的例子中,更好的解决方案是使用e.target != this.$el

代码语言:javascript
复制
mounted() {
    window.addEventListener('click', (e)=>{
        if(e.target !== this.$el)
            this.showChild = false;
    })
}
票数 2
EN
查看全部 5 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48798216

复制
相关文章

相似问题

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