refactor(core): have different data types for each node. (#14120)
Also have a new node type for queries. This leads to less memory usage and better performance. Deep Tree Benchmark results (depth 11): - createAndDestroy (view engine vs current codegen): * pureScriptTime: 78.80+-4% vs 72.34+-4% * scriptTime: 78.80+-4% vs 90.71+-9% * gc: 5371.66+-108% vs 9717.53+-174% * i.e. faster when gc is also considered and about 2x less memory usage! - update unchanged Part of #14013 PR Close #14120
This commit is contained in:

committed by
Miško Hevery

parent
7ad616a177
commit
f802194c18
@ -8,7 +8,7 @@
|
||||
|
||||
import {NgIf} from '@angular/common';
|
||||
import {Component, NgModule, TemplateRef, ViewContainerRef, ViewEncapsulation} from '@angular/core';
|
||||
import {BindingType, DefaultServices, NodeFlags, NodeUpdater, ViewData, ViewDefinition, ViewFlags, anchorDef, checkAndUpdateView, createRootView, elementDef, providerDef, textDef, viewDef} from '@angular/core/src/view/index';
|
||||
import {BindingType, DefaultServices, NodeFlags, NodeUpdater, ViewData, ViewDefinition, ViewFlags, anchorDef, asElementData, asProviderData, checkAndUpdateView, createRootView, elementDef, providerDef, textDef, viewDef} from '@angular/core/src/view/index';
|
||||
import {DomSanitizer, DomSanitizerImpl, SafeStyle} from '@angular/platform-browser/src/security/dom_sanitization_service';
|
||||
|
||||
import {TreeNode, emptyTree} from '../util';
|
||||
@ -25,7 +25,7 @@ let viewFlags = ViewFlags.DirectDom;
|
||||
|
||||
const TreeComponent_Host: ViewDefinition = viewDef(viewFlags, [
|
||||
elementDef(NodeFlags.None, null, 1, 'tree'),
|
||||
providerDef(NodeFlags.None, null, TreeComponent, [], null, null, null, () => TreeComponent_0),
|
||||
providerDef(NodeFlags.None, null, 0, TreeComponent, [], null, null, () => TreeComponent_0),
|
||||
]);
|
||||
|
||||
const TreeComponent_1: ViewDefinition = viewDef(
|
||||
@ -33,7 +33,7 @@ const TreeComponent_1: ViewDefinition = viewDef(
|
||||
[
|
||||
elementDef(NodeFlags.None, null, 1, 'tree'),
|
||||
providerDef(
|
||||
NodeFlags.None, null, TreeComponent, [], {data: [0, 'data']}, null, null,
|
||||
NodeFlags.None, null, 0, TreeComponent, [], {data: [0, 'data']}, null,
|
||||
() => TreeComponent_0),
|
||||
],
|
||||
(updater: NodeUpdater, view: ViewData) => {
|
||||
@ -46,7 +46,7 @@ const TreeComponent_2: ViewDefinition = viewDef(
|
||||
[
|
||||
elementDef(NodeFlags.None, null, 1, 'tree'),
|
||||
providerDef(
|
||||
NodeFlags.None, null, TreeComponent, [], {data: [0, 'data']}, null, null,
|
||||
NodeFlags.None, null, 0, TreeComponent, [], {data: [0, 'data']}, null,
|
||||
() => TreeComponent_0),
|
||||
],
|
||||
(updater: NodeUpdater, view: ViewData) => {
|
||||
@ -62,9 +62,11 @@ const TreeComponent_0: ViewDefinition = viewDef(
|
||||
[[BindingType.ElementStyle, 'backgroundColor', null]]),
|
||||
textDef([' ', ' ']),
|
||||
anchorDef(NodeFlags.HasEmbeddedViews, null, 1, TreeComponent_1),
|
||||
providerDef(NodeFlags.None, null, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}),
|
||||
providerDef(
|
||||
NodeFlags.None, null, 0, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}),
|
||||
anchorDef(NodeFlags.HasEmbeddedViews, null, 1, TreeComponent_2),
|
||||
providerDef(NodeFlags.None, null, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}),
|
||||
providerDef(
|
||||
NodeFlags.None, null, 0, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}),
|
||||
],
|
||||
(updater: NodeUpdater, view: ViewData) => {
|
||||
const cmp = view.component;
|
||||
@ -87,8 +89,8 @@ export class AppModule {
|
||||
}
|
||||
bootstrap() {
|
||||
this.rootView = createRootView(new DefaultServices(null, this.sanitizer), TreeComponent_Host);
|
||||
this.rootComp = this.rootView.nodes[1].provider.instance;
|
||||
this.rootEl = this.rootView.nodes[0].elementOrText.node;
|
||||
this.rootComp = asProviderData(this.rootView, 1).instance;
|
||||
this.rootEl = asElementData(this.rootView, 0).renderElement;
|
||||
}
|
||||
tick() { checkAndUpdateView(this.rootView); }
|
||||
}
|
||||
|
Reference in New Issue
Block a user