Performance Improvements for Vnode.normalizeChildren()
#3051
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Improves
Vnode.normalizeChildren()
performance by avoiding array re-creation, merging loops, reducing comparisons, and performing key consistency checks after normalization without breaking existing behavior.Description
This change improves the performance of
Vnode.normalizeChildren()
by:result of
npm run perf
npm run perf
(on my laptop, node v22)Based on the results of #3041, this change improves performance by about 5% for "rerender same tree".
Motivation and Context
Earlier, I found that performance could be improved by avoiding array re-creation and removing consistency checks, as in v1.
However, that approach clearly broke the current behavior, so I did not include it in #3041.
After further investigation, it turned out that similar performance improvements could be achieved without breaking the current behavior.
Although I’m slightly disappointed by the small increase in bundle size introduced in this PR after #3050, I’m pleased with the noticeable performance improvements.
How Has This Been Tested?
npm run test
Types of changes
Checklist