This repository has been archived by the owner on Feb 22, 2018. It is now read-only.
Change the compiler to use template elements instead of comments for view ports #1365
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.
DON'T MERGE
Using template elements makes viewports queryable, so we don't have to walk the DOM ourselves and rely on querySelectAll. It looks like the change causes a 10% performance degradation. This requires some investigation.
UPDATE:
I've written a new benchmark (#1384) to investigate this issue.
My findings:
The tree benchmark uses the following template:
Which gets compiled to:
There are not elements with the
ng-binding
class in this template, which means that ViewFactory does not have to callquerySelectAll
.After replacing the comment element with the template element, you get:
This time you have two elements with the
ng-binding
class, which means that ViewFactory has to callquerySelectAll
.Calling
querySelectAll
is expensive, and that is why compiling the second template is about 30% slower (which causes a 10% performance degradation).If you, however, change the template to:
Then ViewFactory will have to call
querySelectAll
in both cases, and the template option becomes a tiny bit faster (about 4%), which has almost no effect on the overall performance.