码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 手写ngIf,使用视图容器引用ViewContainerRef和模板引用TemplateRef


    写这篇博客的原有:虽然Angular官网有提到指令的使用,以及相关Ref的使用,但是对相关Ref并没有做出详细的解释,也没有提供相关的详细文档。

    明确 *ngIf 是一个结构型指令,需要 @Directive 修饰器

    2022/11/11 更新

    注:前提知识

    Angular官方并没有给出 simpleChange 的用法

    let change = changes ["expressionResult"]; 是获取到某个属性的change状态

    1. @Directive({
    2. selector: '[fuckIf]'
    3. })
    4. export class FuckStructureDirective{
    5. constructor(private container:ViewContainerRef, private temple:TemplateRef<Object>) {
    6. @Input("fuckIf") expressionResult:boolean;
    7. ngOnchanges(changes:{ [property:string]:SimpleChange })
    8. {
    9. let change = changes ["expressionResult"];// 看看清楚啊 change和changes
    10. if (!change.isFirstChange() && !change.currentValue)
    11. {
    12. this.container.clear();
    13. }
    14. else if (change.currentValue)
    15. {
    16. this.container.createEmbeddedView(this.template)
    17. }
    18. }
    19. }
    20. }

    解释一下这段代码:

    ViewContainerRef 对象用于管理视图容器,是视图的集合。视图就是 包含指令,绑定,表达式的HTML元素区域。

    视图的创建通过ViewContainerRef类提供的各种API来实现。如下图:

     手写 *ngIf时候用到两个方法: 

     createEmbeddedView()向用户显示 ng-temple 元素的内容,然后使用 clear( ) 来删除。

    那么:

    container:ViewContainerRef 代表 ng-temple元素在 HTML 文档中占用的地方

    temple:TemplateRef 代表 ng-temple 元素的内容

    注:changes:{[propKey:string]:SimpleChange}是什么?  索引签名,用于限制对象属性类型 一文读懂TS索引签名 - Yune_Neko - 博客园

    意思是 用 string 去索引,得到一个 SimpleChange类型对象;

     此class会在初始化期间,调用 ngOnChanges方法,他接受SimpleChange 对象,根据表达式当前的值来判断是否显示当前的内容。

    注:* 前缀是Angular的简洁语法

    星号(*)前缀
    星号是一个用来简化更复杂语法的“语法糖”。 从内部实现来说,Angular 把 *ngIf 属性 翻译成一个 元素 并用它来包裹宿主元素,代码如下:

    ngIf 指令

    "hero" class="name">{{hero.name}}

    等价于

    1. "hero">
    2.   <div class="name">{{hero.name}}div>
  • 相关阅读:
    TopSAP天融信 LINUX客户端 CentOS版安装
    PaddleOCR学习笔记1-初步尝试
    【vue实战项目】通用管理系统:api封装、404页
    【科学文献计量】知识单元的频次统计与分布(简单阅览和完整频次统计)
    day15 | 层序遍历、 226.翻转二叉树、 101. 对称二叉树
    NLP | XLNet :用于语言理解的广义自回归预训练 论文详解
    Spring Boot配置文件
    AQS很难,面试不会?看我一篇文章吊打面试官
    亮相2022南京软博会,创邻科技携Galaxybase图平台展现信创硬核实力
    大数据时代下统计数据质量的影响因素
  • 原文地址:https://blog.csdn.net/dongnihao/article/details/127730260
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号