从非根组件的路由跳转到根组件,有内存泄漏问题,组件已销毁,但DOM Nodes没有减少 #2409
Unanswered
Gcgetget
asked this question in
Help and Questions
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
Reproduction
从非根组件的路由跳转到根组件,有内存泄漏问题
Steps to reproduce the bug
在首面,通过路由跳转到table box组件,再从table box组件通过路由跳转到首页,手动进行垃圾回收,DOM Nodes并没有减少,说明存在内存泄漏问题。如下图演示:
data:image/s3,"s3://crabby-images/19a0b/19a0b66874d457473c94c82ee642a54f410ac428" alt="image"
data:image/s3,"s3://crabby-images/5ef76/5ef7621ea1ccc625d3f067f1292d634bab9673a0" alt="image"
data:image/s3,"s3://crabby-images/88493/884938a948377ee86e9e2aa834ce21242018948f" alt="image"
data:image/s3,"s3://crabby-images/31315/31315c73ebaa5b63a8e36480d8b8e320a54fb1aa" alt="image"
路由跳转到table box组件:
在table box组件跳转到首页:
手动垃圾回收,DOM Nodes并没有减少
但是,在table box组件,点击首页的路由Go to home,则不会有内存泄漏
data:image/s3,"s3://crabby-images/ac0f5/ac0f510ab1b6cc4d93e10f297e54a5282a86ce17" alt="image"
data:image/s3,"s3://crabby-images/008d1/008d1e785f63bf0f3689a2e6ec92c5a0272e1ae1" alt="image"
跳转后:
路由配置:
data:image/s3,"s3://crabby-images/0852d/0852dda80144850666a4de454f4810045b74602a" alt="image"
data:image/s3,"s3://crabby-images/d7eaa/d7eaa0d5e9eb4dbc7de31ad75de947709b8e5b73" alt="image"
data:image/s3,"s3://crabby-images/9fb05/9fb053f4297608e081601715cf345fb84dbbe5f9" alt="image"
data:image/s3,"s3://crabby-images/96204/9620430be2672bb5b2a5bd14a236cdcb171615eb" alt="image"
App.vue:
RouterNav.vue:
table box组件:
Expected behavior
从首页路由跳转到table box组件,再从table box组件通过路由跳转到首页,table box组件销毁,DOM Nodes应该下降
Actual behavior
从首页路由跳转到table box组件,再从table box组件通过路由跳转到首页,table box组件销毁,DOM Nodes没有下降,说明有内存泄漏风险
Additional information
"vue": "^3.4.29",
"vue-router": "^4.4.5"
Beta Was this translation helpful? Give feedback.
All reactions