Skip to content

Latest commit

 

History

History
101 lines (71 loc) · 2.26 KB

README.md

File metadata and controls

101 lines (71 loc) · 2.26 KB

vue-memleak

It seems that DOM nodes are not collectable by GC on first route visit under specific circumstances.

Project setup

npm install

Serve production build

npm run servep

Reproduce memory leak on first route visit

  1. Serve production build
  2. Open browser and navigate to locally served project (e.g. localhost:5000)
  3. Open dev tools
  4. Navigate to "Case 3" and back to "Home"
  5. Issue garbage collection manually
    (DOM nodes from "Case 3"-view stick)
  6. Navigate again to "Case 3" and back to "Home"
  7. Issue garbage collection manually
    (DOM nodes from "Case 3"-view visit 1 still stick, but DOM nodes from visit 2 are GC'ed)

Optional:

Confirm DOM nodes from "Case 1" and "Case 2" routes are GC'ed as expected
(to rule out FooBar.List.vue as mem leak source):

  • Navigate to "Case 1|2" and back to "Home"
  • Issue garbage collection manually (DOM nodes from "Case 1|2" are GC'ed)

Confirm DOM nodes of FIRST visit stick (and not from the last visit):

  • Case 4 has 100 list items
  • Case 4 (500 items) has 500 list items

The number of detached / leaked nodes depend on which version of the case 4 view was opened first.

Assumption

Components with a single root and multiple children cause memory leak:

No mem leak: No single root. Multiple children (Case 1)

<template>

    <h1>Case 1 (no mem leak)</h1>

    <FooBarList/>

</template>

No mem leak: Single root with one children (Case 2)

<template>

  <div>
    <FooBarList/>
  </div>

</template>

MEM LEAK: Single root with multiple children (Case 3)

<template>

    <div>
      <h1>Case 3 (mem leak)</h1>

      <FooBarList/>
    </div>

</template>

How the leak looks like

Each route opened the first time contributes to a new baseline.

(numbers = case view opened / GC'ed) 105529843-4cc34b00-5ce7-11eb-853c-98d682b3eb83

Additional scripts

Compiles and hot-reloads for development

npm run serve

Compiles and minifies for production

npm run build

Lints and fixes files

npm run lint

Customize configuration

See Configuration Reference.