this.$emit vs. this.$root.$emit,vuejs 最佳实践

如何解决this.$emit vs. this.$root.$emit,vuejs 最佳实践

我有使用 ''' document.addEventListener('DOMContentLoaded',function() { // Use buttons to toggle between views document.querySelector('#inBox').addEventListener('click',() => load_mailBox('inBox')); document.querySelector('#sent').addEventListener('click',() => load_mailBox('sent')); document.querySelector('#archived').addEventListener('click',() => load_mailBox('archive')); document.querySelector('#test').addEventListener('click',compose_email); document.querySelector('#compose').addEventListener('click',compose_email); // By default,load the inBox load_mailBox('inBox'); }); function compose_email() { // Show compose view and hide other views document.querySelector('#emails-view').style.display = 'none'; document.querySelector('#compose-view').style.display = 'block'; // Clear out composition fields document.querySelector('#compose-recipients').value = ''; document.querySelector('#compose-subject').value = ''; document.querySelector('#compose-body').value = ''; }; function load_mailBox(mailBox) { // Show the mailBox and hide other views document.querySelector('#emails-view').style.display = 'block'; document.querySelector('#compose-view').style.display = 'none'; // Show the mailBox name document.querySelector('#emails-view').innerHTML = `<h3>${mailBox.charat(0).toupperCase() + mailBox.slice(1)}</h3>`; }; ''' 添加删除的 vue2 组件。在某些情况下,我通过发送方的 v-if 和接收方的 $emit 在它们之间进行通信。

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

我有两个问题:

  1. beforeDestroythis.$root.$emit 有什么区别?
  2. 如果我使用 this.$emit,是否还需要将它与 this.$on 配对?还是在移除组件时处理程序会自动关闭”?

解决方法

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

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

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

  1. 如果我使用 this.$on,是否还需要将它与 this.$off 配对?还是在移除组件时处理程序会自动“关闭”?

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

,

提醒一下,除非某些特殊情况,否则通常 root 发出永远不是一个好主意。为了支持这一点,实际上 vue3 删除了它的支持。

我什至不知道你为什么需要 $on,因为即使是那些几乎都是边缘情况。

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?