- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有两个组件。 parent 和 child 。父级根据 v-if
加载子级。然后 child 通过$emit
发送一个事件告诉 parent 移除 child 。
简单地说。
家长:
data() {
return {
show: false
}
},
// template:
<div>
<div @click="show = !show">Toggle</div>
<child-component
v-if="show"
@close="show = false"
/>
</div>
child :
template:
<div>
Some Content
<div @click="$emit('close')">Close</div>
</div>
问题是当 $emit('close')
被触发时,子组件从 DOM 中移除但组件没有从内存中清除。
如果 parent 使用 toggle
按钮移除 child ,它确实会从内存中清除 child 。
我也尝试过使用 Vuex store
和 $root.data
但这也会导致内存泄漏。
换句话说,如果子进程向父进程发出信号,表明它应该被移除,它就会保留在内存中。但是,如果 parent 直接删除 child (没有来自 child 的任何信号),它就会从内存中删除......
知道为什么会发生这种情况以及我应该如何防止这种内存泄漏? child 必须发出要移除的信号。
[编辑] - 代码笔中的演示。 https://codepen.io/tomshort5/pen/BaBLXvb
通过在某些操作后制作内存快照,可以最好地看到这一点。当页面加载时,我们有一个 Vue 实例。
点击toggle后,一个VueComponent就按预期创建了。
通过事件触发child移除后,VueComponent并没有从内存中移除。将它与再次单击“切换”进行比较时,它确实显示了从内存中删除的组件。
最佳答案
我有一个部分的解释。
似乎有什么东西保留了对被单击的最后一个 DOM 节点的引用。所以如果你点击 Close
它将获取对该文本节点的引用。文本节点的父节点是 <div>
和 <div>
有一个指向 Vue 组件的点击监听器。组件本身已被销毁,无法进行 GC。
如果您改为单击 Toggle
它保留对 Toggle
的引用文本节点。由于该节点位于 DOM 树的不同部分,因此它不会使用点击监听器保留对该元素的任何引用。 Vue组件成功GCed。
我无法准确确定是什么保留了对上次单击节点的引用。堆快照不是特别有用。它只显示 InternalNode
正在连接 window
到相关的文本节点。
我确实在没有 Vue 的情况下整理了一个页面来探索这个。我的实验表明,即使 Vue 不在页面上,也会保留对最后单击的节点的引用。
这里的内存泄漏只是非常暂时的。在页面上的任意位置再单击一次似乎足以修复它。与我的理论一致,这更新了“最后单击的节点”引用,允许分离的 DOM 节点和 Vue 组件一起被 GC。
关于vue.js - $emit 导致内存泄漏 - Vue.js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57578842/
我只是偶然发现了一个似乎广为人知的compsci关键字“emit”。但是我找不到用通用计算机科学术语对其的任何明确定义,也找不到任何特定编程语言中的“emit()”函数或关键字的特定定义。 我在这里找
在 Qt 中,它们都是有效的,并且表现相同: emit someSignal(value); 对比 emit(someSignal(value)); 有什么区别吗? 最佳答案 Is there any
是否可以同步执行并在调用方法本身时返回结果。所以,我想在 $emit 完成后执行下一条语句。其如下: Parent component has method, doC
我是 socket.io 的新手,遇到了一些看起来很奇怪的事情。我实际上不知道 socket.emit 和 io.emit 之间的区别,但我在任何地方都找不到解释。 io.on('connection
有谁知道如何显式实现接口(interface)的属性 使用反射。发射? 最佳答案 有关 TypeBuilder.DefineMethodOverride 的信息,请参阅 MSDN 文档,其中包括使用
我有多个可观察对象进行网络调用,并且仅当所有可观察对象发出错误时,我才需要从组合器可观察对象发出错误。如果至少有一个可观察完成,则应传递结果。 我当前的流功能如下: Observable.fromIt
我想在这里实现的是当 IF 语句为 true 时 fightID 更改为其他值,因此它不会匹配它之前分配的值,因此我无法在战斗结束后立即通过控制台运行 win-fight 发出的消息。但是我现在得到的
当我们需要自定义组件在 VueTable2 中发出事件时,我们必须使用: this.$parent.$emit('myCustomEvent') // instead of this.$emit('m
This is my production webpack config .标题中的两个引号分别指的是 webpack2 和 webpack。两者都因类似的错误而挂起。 这是我触发构建的命令 设置 N
我正在尝试构建一个发布者,它会在其他 5 个发布者中的任何一个发布者发出 true 时发出 true。我已经设法构建了一个工作版本,但感觉非常恶心,使用 CombineLatest4 + Combin
我正在尝试创建用于教育目的的简单 .net 编译器。在解析、扫描和构建 AST 之后,我正在使用 Reflection.Emit.ILGenerator 生成 .net 程序集。 这是我的程序集生成示
以下 node.js 脚本不工作 var EventEmitter = require('events').EventEmitter; var util = require('util'); var
我使用的是Laravel 10,Livewire 2.x,我试图使用Livewire组件中的一个简单函数中的emit或emitTo事件来更新愿望列表计数。。WishlistCount控制器:。当我运行
我收到以下警告: [Vue warn]: Extraneous non-emits event listeners (addData) were passed to component but cou
我不明白 io.emit 和 io.sockets.emit 之间有什么区别。 有时它们的行为相同,但有时它们的行为不同。 最佳答案 socket.emit 仅将消息发送到发送者客户端 io.emit
我刚刚成功地使用 socket.io 连接到一个服务器脚本,所以我很高兴。我对我的脚本生成的奇怪行为不太满意:我在单击按钮时向服务器脚本发送一个发射,然后服务器测试脚本向控制台日志发回一条消息 6x。
这听起来可能有点模糊,但我仍在学习并试图理解它是如何工作的。 我开始使用“侧菜单”启动 ionic 项目,它已经设置了带有“应用程序”抽象状态/ View / Controller 的 urlrout
我遵循了一些 Nodejs 教程并完成了一个简单的 REST Web 服务。此 Web 服务监听/api/accounts 中的电子邮件和密码,然后继续在 Cassandra 集群中进行查找。我使用
我正在尝试建立一种模式,在这种模式下,我的产生某些对象的可观察对象被转换为领域事件,例如围绕可观察对象产生的 Started、Success、Error,如果这有意义的话 public Observa
这个问题已经有答案了: How can I let the javascript catch a signal from node and prompt a window right after th
我是一名优秀的程序员,十分优秀!