温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-10-12 16:10:14 来源:亿速云 阅读:162 作者:柒染 栏目:云计算

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: <input type="text">})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属性和其值的生成时机是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI