zoukankan      html  css  js  c++  java
  • 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" [formControl]="favoriteColorControl">
      `
    })
    export class ReactFormComponent {
      favoriteColorControl = new FormControl('');
    }
    

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

    bootstrap里调用_loadComponent:

    changeDetectorRef的策略:RootViewRef:

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

    loadComponent里显式调用tick:

    tick函数里进行change detect:

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

    element指向input控件:

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

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

    ng-reflect-form

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

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

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

    important takeaway

    setNgReflectProperty函数

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

  • 相关阅读:
    Mysql查询数据库表结构以及字段类型并展示
    Configutation读取properties文件信息
    通过淘宝接口免费获取IP地址信息
    SpringMVC+SPring+Maven+Mybaits+Shiro+Mybaits基础开发项目
    【微信开发】【Asp.net MVC】-- 微信分享功能
    NPOI导出多张图片到Excel
    年末回想 ---- 小步快跑
    【吉光片羽】短信验证
    【JavaScript吉光片羽】--- 滑动条
    电子书和纸质书有什么区别
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/14240625.html
Copyright © 2011-2022 走看看