关于施加在 div 标签上的 ngTemplateOutlet 指令让 div class 丢失的问题调试

简介: 关于施加在 div 标签上的 ngTemplateOutlet 指令让 div class 丢失的问题调试

本文描述的应用代码地址: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 元素即可,如下图所示:

相关文章
|
4月前
|
前端开发
css div覆盖样式(一个div想覆盖掉另一个div在他上面进行显示)
css div覆盖样式(一个div想覆盖掉另一个div在他上面进行显示)
41 0
|
10月前
|
JavaScript
js通过input框输入属性和值,改变div的属性
js通过input框输入属性和值,改变div的属性
105 0
|
14天前
<div>标记
<div>标记。
24 3
|
25天前
|
容器
div标记
【8月更文挑战第26天】div标记。
26 4
|
1月前
|
前端开发
如何消除li和ul之间的空隙、如何使div中的内容居中
这篇文章介绍了如何美化网页元素,包括设置登录页面的模糊背景效果,使用CSS的`opacity`属性;以及如何使`div`中的内容水平居中,通过设置`margin: auto;`。此外,还讲解了如何消除`li`和`ul`之间的空隙,通过将`ul`和`li`的`padding`和`margin`设置为0。
如何消除li和ul之间的空隙、如何使div中的内容居中
我们有很多属性,一种是天生自带的属性,div{$}*5能够一次性生成5个div的写法
我们有很多属性,一种是天生自带的属性,div{$}*5能够一次性生成5个div的写法
|
2月前
【el-cascader-plus亲测有限】el-cascader级联选择器懒加载+多选功能回显失败解决方案
【el-cascader-plus亲测有限】el-cascader级联选择器懒加载+多选功能回显失败解决方案
74 0
|
4月前
|
JavaScript
为什么把script标签放在div下面?
为什么把script标签放在div下面?
|
4月前
layui根据数据状态判断显示内容
layui根据数据状态判断显示内容
141 0
|
11月前
|
JSON 小程序 前端开发
小程序不引入基础组件实现weui使用(附加小程序换行显示)
小程序不引入基础组件实现weui使用(附加小程序换行显示)