refactor(ivy): extract elementStart first create pass (#33963)
PR Close #33963
This commit is contained in:
parent
04b12fc0d6
commit
478f8821a0
|
@ -10,11 +10,11 @@ import {assertDataInRange, assertDefined, assertEqual} from '../../util/assert';
|
||||||
import {assertHasParent} from '../assert';
|
import {assertHasParent} from '../assert';
|
||||||
import {attachPatchData} from '../context_discovery';
|
import {attachPatchData} from '../context_discovery';
|
||||||
import {registerPostOrderHooks} from '../hooks';
|
import {registerPostOrderHooks} from '../hooks';
|
||||||
import {TAttributes, TNode, TNodeFlags, TNodeType} from '../interfaces/node';
|
import {TAttributes, TElementNode, TNode, TNodeFlags, TNodeType} from '../interfaces/node';
|
||||||
import {RElement} from '../interfaces/renderer';
|
import {RElement} from '../interfaces/renderer';
|
||||||
import {StylingMapArray, TStylingContext} from '../interfaces/styling';
|
import {StylingMapArray, TStylingContext} from '../interfaces/styling';
|
||||||
import {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';
|
import {isContentQueryHost, isDirectiveHost} from '../interfaces/type_checks';
|
||||||
import {HEADER_OFFSET, LView, RENDERER, TVIEW, T_HOST} from '../interfaces/view';
|
import {HEADER_OFFSET, LView, RENDERER, TVIEW, TView, T_HOST} from '../interfaces/view';
|
||||||
import {assertNodeType} from '../node_assert';
|
import {assertNodeType} from '../node_assert';
|
||||||
import {appendChild} from '../node_manipulation';
|
import {appendChild} from '../node_manipulation';
|
||||||
import {decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getSelectedIndex, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode} from '../state';
|
import {decreaseElementDepthCount, getBindingIndex, getElementDepthCount, getIsParent, getLView, getNamespace, getPreviousOrParentTNode, getSelectedIndex, increaseElementDepthCount, setIsNotParent, setPreviousOrParentTNode} from '../state';
|
||||||
|
@ -25,7 +25,29 @@ import {getConstant, getNativeByTNode, getTNode} from '../util/view_utils';
|
||||||
import {createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, renderInitialStyling, resolveDirectives, saveResolvedLocalsInData, setInputsForProperty} from './shared';
|
import {createDirectivesInstances, elementCreate, executeContentQueries, getOrCreateTNode, matchingSchemas, renderInitialStyling, resolveDirectives, saveResolvedLocalsInData, setInputsForProperty} from './shared';
|
||||||
import {registerInitialStylingOnTNode} from './styling';
|
import {registerInitialStylingOnTNode} from './styling';
|
||||||
|
|
||||||
|
function elementStartFirstCreatePass(
|
||||||
|
index: number, tView: TView, lView: LView, native: RElement, name: string,
|
||||||
|
attrsIndex?: number | null, localRefsIndex?: number): TElementNode {
|
||||||
|
ngDevMode && ngDevMode.firstCreatePass++;
|
||||||
|
|
||||||
|
const tViewConsts = tView.consts;
|
||||||
|
const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);
|
||||||
|
const tNode = getOrCreateTNode(tView, lView[T_HOST], index, TNodeType.Element, name, attrs);
|
||||||
|
|
||||||
|
if (attrs !== null) {
|
||||||
|
registerInitialStylingOnTNode(tNode, attrs, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
const hasDirectives =
|
||||||
|
resolveDirectives(tView, lView, tNode, getConstant<string[]>(tViewConsts, localRefsIndex));
|
||||||
|
ngDevMode && validateElement(lView, native, tNode, hasDirectives);
|
||||||
|
|
||||||
|
if (tView.queries !== null) {
|
||||||
|
tView.queries.elementStart(tView, tNode);
|
||||||
|
}
|
||||||
|
|
||||||
|
return tNode;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create DOM element. The instruction must later be followed by `elementEnd()` call.
|
* Create DOM element. The instruction must later be followed by `elementEnd()` call.
|
||||||
|
@ -45,25 +67,26 @@ export function ɵɵelementStart(
|
||||||
index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {
|
index: number, name: string, attrsIndex?: number | null, localRefsIndex?: number): void {
|
||||||
const lView = getLView();
|
const lView = getLView();
|
||||||
const tView = lView[TVIEW];
|
const tView = lView[TVIEW];
|
||||||
const tViewConsts = tView.consts;
|
const adjustedIndex = HEADER_OFFSET + index;
|
||||||
const attrs = getConstant<TAttributes>(tViewConsts, attrsIndex);
|
|
||||||
const localRefs = getConstant<string[]>(tViewConsts, localRefsIndex);
|
|
||||||
ngDevMode && assertEqual(
|
ngDevMode && assertEqual(
|
||||||
getBindingIndex(), tView.bindingStartIndex,
|
getBindingIndex(), tView.bindingStartIndex,
|
||||||
'elements should be created before any bindings');
|
'elements should be created before any bindings');
|
||||||
ngDevMode && ngDevMode.rendererCreateElement++;
|
ngDevMode && ngDevMode.rendererCreateElement++;
|
||||||
ngDevMode && assertDataInRange(lView, index + HEADER_OFFSET);
|
ngDevMode && assertDataInRange(lView, adjustedIndex);
|
||||||
|
|
||||||
const renderer = lView[RENDERER];
|
const renderer = lView[RENDERER];
|
||||||
const native = lView[index + HEADER_OFFSET] = elementCreate(name, renderer, getNamespace());
|
const native = lView[adjustedIndex] = elementCreate(name, renderer, getNamespace());
|
||||||
const tNode = getOrCreateTNode(tView, lView[T_HOST], index, TNodeType.Element, name, attrs);
|
|
||||||
|
|
||||||
|
const tNode = tView.firstCreatePass ?
|
||||||
|
elementStartFirstCreatePass(index, tView, lView, native, name, attrsIndex, localRefsIndex) :
|
||||||
|
tView.data[adjustedIndex] as TElementNode;
|
||||||
|
setPreviousOrParentTNode(tNode, true);
|
||||||
|
|
||||||
|
const attrs = tNode.attrs;
|
||||||
if (attrs != null) {
|
if (attrs != null) {
|
||||||
const lastAttrIndex = setUpAttributes(renderer, native, attrs);
|
setUpAttributes(renderer, native, attrs);
|
||||||
if (tView.firstCreatePass) {
|
|
||||||
registerInitialStylingOnTNode(tNode, attrs, lastAttrIndex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((tNode.flags & TNodeFlags.hasInitialStyling) === TNodeFlags.hasInitialStyling) {
|
if ((tNode.flags & TNodeFlags.hasInitialStyling) === TNodeFlags.hasInitialStyling) {
|
||||||
renderInitialStyling(renderer, native, tNode, false);
|
renderInitialStyling(renderer, native, tNode, false);
|
||||||
}
|
}
|
||||||
|
@ -78,25 +101,12 @@ export function ɵɵelementStart(
|
||||||
}
|
}
|
||||||
increaseElementDepthCount();
|
increaseElementDepthCount();
|
||||||
|
|
||||||
// if a directive contains a host binding for "class" then all class-based data will
|
|
||||||
// flow through that (except for `[class.prop]` bindings). This also includes initial
|
|
||||||
// static class values as well. (Note that this will be fixed once map-based `[style]`
|
|
||||||
// and `[class]` bindings work for multiple directives.)
|
|
||||||
if (tView.firstCreatePass) {
|
|
||||||
ngDevMode && ngDevMode.firstCreatePass++;
|
|
||||||
const hasDirectives = resolveDirectives(tView, lView, tNode, localRefs);
|
|
||||||
ngDevMode && validateElement(lView, native, tNode, hasDirectives);
|
|
||||||
|
|
||||||
if (tView.queries !== null) {
|
|
||||||
tView.queries.elementStart(tView, tNode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isDirectiveHost(tNode)) {
|
if (isDirectiveHost(tNode)) {
|
||||||
createDirectivesInstances(tView, lView, tNode);
|
createDirectivesInstances(tView, lView, tNode);
|
||||||
executeContentQueries(tView, tNode, lView);
|
executeContentQueries(tView, tNode, lView);
|
||||||
}
|
}
|
||||||
if (localRefs != null) {
|
if (localRefsIndex != null) {
|
||||||
saveResolvedLocalsInData(lView, tNode);
|
saveResolvedLocalsInData(lView, tNode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -239,6 +239,9 @@
|
||||||
{
|
{
|
||||||
"name": "elementCreate"
|
"name": "elementCreate"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "elementStartFirstCreatePass"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "enterDI"
|
"name": "enterDI"
|
||||||
},
|
},
|
||||||
|
|
|
@ -527,6 +527,9 @@
|
||||||
{
|
{
|
||||||
"name": "elementPropertyInternal"
|
"name": "elementPropertyInternal"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "elementStartFirstCreatePass"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "enterDI"
|
"name": "enterDI"
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue