美文网首页
关于施加在 div 标签上的 ngTemplateOutlet

关于施加在 div 标签上的 ngTemplateOutlet

作者: 华山令狐冲 | 来源:发表于2022-03-16 10:34 被阅读0次

本文描述的应用代码地址:https://github.com/wangzixi-diablo/ngDynamic

问题描述

我在 div 标签页里使用 ngTemplateOutlet 给代码第 11 行的 div 标签动态传入了一个新的模板实例,该实例通过变量 inputTemplate 代表。

运行时,我发现第 11 行的 div 标签,完全被传入的 inputTemplate 变量代表的模板实例所替换——原来那个具有 wrapper2 class 的 div 标签完全消失了。

同时另一个附带发现,将 div 替换成 ng-content 以及 ng-container,最后的效果完全没有区别。似乎 ngTemplateOutlet 会将指向的模板实例的 layout,完全替换施加了 ngTemplateOutlet 的 wrapper 元素。

问题分析

在 core.js 的 templateRef.createEmbeddedView 设置断点:

断点触发后,切换到 elements 标签页,发现第二个 div 标签根本就不可见。

再在下列代码里设置断点,也就是 Angular bootstrap 阶段,让其暂停下来:

bootstrapModule(moduleType, compilerOptions = []) {
        const options = optionsReducer({}, compilerOptions);
        return compileNgModuleFactory(this.injector, options, moduleType)
            .then(moduleFactory => this.bootstrapModuleFactory(moduleFactory, options));
    }

此时的 HTML 页面:


仅仅包含了 app-ng-template,也就是 app.module.ts 里指定的 bootstrap Component:

我们可以关注这段代码的生成时机:

<!--bindings={
  "ng-reflect-ng-template-outlet": "[object Object]"
}-->

这里执行 template input 的内联 HTML 模板:

使用函数 ɵɵproperty 更新一个 HTML element 的 property

属性名称,就是 div 上施加的结构性指令 ngTemplateOutlet,value 就是通过 @Input 传入的类型为 TemplateRef 的模板实例:

我们最后在 Chrome 开发者工具 elements 标签页里看到的字段 ng-reflect-ng-template-outlet 的值,实际上就是 value.toString() 调用的返回结果。

解决方法

如果不希望施加 ngTemplateOutlet 的元素消失,可以仿照本文 wrapper div,在 host 元素外层再包一层 div 元素即可,如下图所示:

相关文章

  • 关于施加在 div 标签上的 ngTemplateOutlet

    本文描述的应用代码地址:https://github.com/wangzixi-diablo/ngDynamic[...

  • :hover 伪类

    简介 当鼠标浮动到div标签上的时候,div标签才会显示出background:red的样式。为了确保生效,:ho...

  • vue 表单阻止默认提交、回车操作

    @submit.native.prevent 阻止默认提交,添加在form标签上@keyup.native.en...

  • Angular目录

    NgIf NgForOf NgTemplateOutlet ElementRef

  • 过渡模块

    过渡效果三要素: 1.hover这个伪类选择器除了可以用在a标签上,还可以用在其他的任何标签上。 div:hove...

  • 002数据绑定

    1 ng-app命令,加在标签上,如 表示这个标签会被angular.js管理 2 {{}}angular.js用...

  • HTML

    HTML(HyperText Markup Language) DOCTYPE选择文档类型。 div、span 标...

  • Vuejs 样式绑定

    本文主要归纳,在 Vuejs 中。如何实现数据与样式进行绑定。 class 对象绑定 在 div 标签上绑定 cl...

  • vue2.0 使用修饰符.native

    在div,span,button标签上不能使用@click.native="mm()" 按钮 当前情况下不能使用修...

  • angular4 一些技巧 ng-content ng-temp

    主要内容: ng-content ng-template *ngTemplateOutlet ng-contain...

网友评论

      本文标题:关于施加在 div 标签上的 ngTemplateOutlet

      本文链接:https://www.haomeiwen.com/subject/tsndrrtx.html