Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机

简单的Component代码:

import { Component } from '@angular/core';
import { FormControl } from '@angular/forms';

@Component({
  selector: 'app-reactive-favorite-color',
  template: `
    Favorite Color: 
  `
})
export class ReactFormComponent {
  favoriteColorControl = new FormControl('');
}

如下图所示:ng-reflect-form这个属性运行时是如何生成的?

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第1张图片

bootstrap里调用_loadComponent:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第2张图片

changeDetectorRef的策略:RootViewRef:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第3张图片

ComponentRef指向的AppComponent,能看到Component的property:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第4张图片

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第5张图片

loadComponent里显式调用tick:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第6张图片

tick函数里进行change detect:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第7张图片

Angular Component html里加了方括号的Directive,浏览器是无法识别的,在Angular core.js里,在执行Component template实现函数时,会调用Angular的ɵɵproperty函数,将中括号包裹的Angular指令展开:Update a property on a selected element.

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第8张图片

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第9张图片

element指向input控件:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第10张图片

需要添加到input标签页的属性名称为form:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第11张图片

经过normalizeDebugBindingValue里面的正则化处理完属性form之后,返回的值:

ng-reflect-form

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第12张图片

待写入input ng-reflect-form属性的值:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第13张图片

为了避免value的值过于复杂时,序列化生成的json字符床过大,污染了最后的原生html,在normalizeDebugBindingValue里只是简单的调用toString函数:
// Limit the size of the value as otherwise the DOM just gets polluted.

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第14张图片

这就是最后在Chrome开发者工具里看到的[object Object]的由来:

Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机_第15张图片

important takeaway

setNgReflectProperty函数

更多Jerry的原创文章,尽在:"汪子熙":

你可能感兴趣的:(angular,form,javascript,node.js,nginx)