网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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

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属性和其值的生成时机是什么

bootstrap里调用_loadComponent:

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

changeDetectorRef的策略:RootViewRef:

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

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

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

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

loadComponent里显式调用tick:

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

tick函数里进行change detect:

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

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属性和其值的生成时机是什么

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

element指向input控件:

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

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

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

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

ng-reflect-form

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

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

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

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

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

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

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

关于Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


本文名称:Angularform控件原生HTML代码里ng-reflect-form属性和其值的生成时机是什么
当前地址:http://bjjierui.cn/article/ghosij.html

其他资讯