首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >$emit与this。$root。$emit,vuejs中的最佳实践。

$emit与this。$root。$emit,vuejs中的最佳实践。
EN

Stack Overflow用户
提问于 2021-06-27 00:09:02
回答 1查看 4.4K关注 0票数 5

我有vue2组件,这些组件是用v-if添加和删除的。在某些情况下,我与来自发送方的$emit和接收方的$on进行通信。

我一直在使用this.$root.$emit广播自定义事件,使用this.$root.$on来处理事件。我发现使用this.$root.$on需要this.$root.$off (来自beforeDestroy),否则被删除的组件可能会尝试处理它,并且会发生不好的事情。

我有两个问题:

this.$emit

  • If和
  1. 的区别是什么?我使用的是this.$on,我也必须将它与this.$off配对吗?或者当组件被移除时,处理程序会自动“关闭”吗?
EN

回答 1

Stack Overflow用户

发布于 2021-06-27 01:29:32

this.$emit

  1. this.$root.$emit有什么区别?

this.$root获取根组件实例(通常是App.vue),因此this.$root.emit从根组件发出一个事件。

this.$emit只是从当前组件发出一个事件。

  1. 如果我使用this.$on,是否也必须将其与this.$off配对?或者当组件被移除时,处理程序会自动“关闭”吗?

不需要this.$off。是的,当组件被销毁时,处理程序将被自动移除。

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

https://stackoverflow.com/questions/68147098

复制
相关文章

相似问题

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