从非根组件的路由跳转到根组件,有内存泄漏问题,组件已销毁,但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/c008f/c008feced08bc72c2a3b2d8e1b65e363394c6a77" alt="image"
data:image/s3,"s3://crabby-images/6b291/6b2913b8d61af30cc1e71b1393cdd3c293893f02" alt="image"
data:image/s3,"s3://crabby-images/d8d39/d8d39484ad028b6c85c3aabead849ffa7f961735" alt="image"
data:image/s3,"s3://crabby-images/119cd/119cdb474b996626dce043678ae9282f218b877e" alt="image"
路由跳转到table box组件:
在table box组件跳转到首页:
手动垃圾回收,DOM Nodes并没有减少
但是,在table box组件,点击首页的路由Go to home,则不会有内存泄漏
data:image/s3,"s3://crabby-images/c50dd/c50dd29759f25a852ac7b05ab2c8be7b50fb17b3" alt="image"
data:image/s3,"s3://crabby-images/b1694/b1694bcd5a928d2aecc444155d10894e24b3b5cc" alt="image"
跳转后:
路由配置:
data:image/s3,"s3://crabby-images/cc14e/cc14e866cc713ce904b6fb4b966547ab1af1bbc6" alt="image"
data:image/s3,"s3://crabby-images/1712c/1712c7046a3572b1184a2bbcdcb8ac763d1505ac" alt="image"
data:image/s3,"s3://crabby-images/85f20/85f20d7dedd90043451d44235e1179d312033e92" alt="image"
data:image/s3,"s3://crabby-images/ab74b/ab74b3fe3d3070adb3c1ce4ad3d380fab59634c4" 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