角形式控件原代生HTML码里ng-reflect-form属性和其值的生成时机是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
简单的组件代码:
import { ,, ,, ,,,Component },得到& # 39;@angular/核心# 39;;import { ,, ,, ,,,FormControl },得到& # 39;@angular/形式# 39;;@ component ({ ,, ,, ,, ,,选择器:& # 39;app-reactive-favorite-color& # 39; 模板:,才能 ,,,Favorite 颜色:,& lt; input 类型=皌ext"祝辞})export class ReactFormComponent { ,, ,, ,, favoriteColorControl 才能=,new FormControl (& # 39; & # 39;);}
如下图所示:ng-reflect-form这个属性运行时是如何生成的?
引导里调用_loadComponent:
changeDetectorRef的策略:RootViewRef:
ComponentRef指向的AppComponent,能看到组件的属性:
loadComponent里显式调用标记:
蜱虫函数里进行变化检测:
HTML里角组件加了方括号的指令,浏览器是无法识别的,在角的核心。js里,在执行组件模板实现函数时,会调用角的? ?财产函数,将中括号包裹的角指令展开:更新属性alt=敖切问娇丶鶫TML码里ng-reflect-form属性和其值的生成时机是什么">
元素指向输入控件:
需要添加到输入标签页的属性名称为形式:
经过normalizeDebugBindingValue里面的正则化处理完属性形式之后,返回的值:
ng-reflect-form
待写入输入ng-reflect-form属性的值:
为了避免值的值过于复杂时,序列化生成的json字符床过大,污染了最后的原生HTML,在normalizeDebugBindingValue里只是简单的调用toString函数:
//限制的大小值另有DOM就被污染了。
这就是最后在Chrome开发者工具里看到的对象(对象)的由来:
关于角形式控件原代生HTML码里ng-reflect-form属性和其值的生成时机是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。