详解Angular 4.x NgTemplateOutlet

发布时间 - 2026-01-11 01:15:50    点击率:

该指令用于基于已有的 TemplateRef 对象,插入对应的内嵌视图。在应用 NgTemplateOutlet 指令时,我们可以通过 [ngTemplateOutletContext] 属性来设置 EmbeddedViewRef 的上下文对象。绑定的上下文应该是一个对象,此外可通过 let 语法来声明绑定上下文对象属性名。

友情提示:若 let 语法未绑定任何属性名,则上下文对象中 $implicit 属性,对应的值将作为默认值。

NgTemplateOutlet 指令语法

复制代码 代码如下:
<ng-container *ngTemplateOutlet="templateRefExp; context: contextExp"></ng-container>

NgTemplateOutlet 使用示例

@Component({
 selector: 'ng-template-outlet-example',
 template: `
 <ng-container *ngTemplateOutlet="greet"></ng-container>
 <hr>
 <ng-container *ngTemplateOutlet="eng; context: myContext"></ng-container>
 <hr>
 <ng-container *ngTemplateOutlet="svk; context: myContext"></ng-container>
 <hr>
 <ng-template #greet><span>Hello</span></ng-template>
 <ng-template #eng let-name><span>Hello {{name}}!</span></ng-template>
 <ng-template #svk let-person="localSk"><span>Ahoj {{person}}!</span></ng-template>
`
})
class NgTemplateOutletExample {
 myContext = {$implicit: 'World', localSk: 'Svet'};
}

基础知识

TemplateRef

TemplateRef 实例用于表示模板对象。

ViewContainerRef

ViewContainerRef 实例提供了 createEmbeddedView() 方法,该方法接收 TemplateRef 对象作为参数,并将模板中的内容作为容器 (comment 元素) 的兄弟元素,插入到页面中。

<ng-template>

<ng-template> 用于定义模板,使用 * 语法糖的结构指令,最终都会转换为 <ng-template> 模板指令,模板内的内容如果不进行处理,是不会在页面中显示。

<ng-container>

<ng-container> 是一个逻辑容器,可用于对节点进行分组,但不作为 DOM 树中的节点,它将被渲染为 HTML中的 comment 元素,它可用于避免添加额外的元素来使用结构指令。

若想进一步了解 <ng-template> <ng-container> 的区别,请参考Angular 4.x 动态创建组件 文章中我有话说版块。

NgTemplateOutlet 源码分析

NgTemplateOutlet 指令定义

@Directive({
 selector: '[ngTemplateOutlet]'
})

NgTemplateOutlet 类私有属性及构造函数

export class NgTemplateOutlet implements OnChanges {
 // 表示创建的内嵌视图
 private _viewRef: EmbeddedViewRef<any>; 
 // 注入ViewContainerRef实例
 constructor(private _viewContainerRef: ViewContainerRef) {}
}

NgTemplateOutlet 类输入属性

@Input() public ngTemplateOutletContext: Object; // 用于设定EmbeddedViewRef上下文
@Input() public ngTemplateOutlet: TemplateRef<any>; // 用于设定TemplateRef对象

NgTemplateOutlet 指令声明周期

export class NgTemplateOutlet implements OnChanges {
 ngOnChanges(changes: SimpleChanges) {
 // 若this._viewRef已存在,则先从视图容器中对应的位置移除该视图。
 if (this._viewRef) {
  this._viewContainerRef.remove(this._viewContainerRef.indexOf(this._viewRef));
 }
 // 若this.ngTemplateOutlet输入属性有绑定TemplateRef对象,则基于设定的上下文对象创建内嵌视图
 if (this.ngTemplateOutlet) {
  this._viewRef = this._viewContainerRef.createEmbeddedView(
   this.ngTemplateOutlet, this.ngTemplateOutletContext);
 }
 }
}

ngTemplateOutlet 指令的源码相对比较简单,如果读者有兴趣了解 createEmbeddedView() 方法的内部实现,可以参考 Angular 4.x NgIf 文章中的相关内容。

另外需要注意的是使用 let 语法创建模板局部变量,若未设置绑定的值,则默认是上下文对象中 $implicit 属性对应的值。为什么属性名是 $implicit 呢?因为 Angular 不知道用户会如何命名,所以定义了一个默认的属性名。 即 let-name="$implicit" let-name 是等价的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Angular  # NgTemplateOutlet  # angular4  # ng  # template 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 中山网站推广排名,中山信息港登录入口?  如何快速查询网址的建站时间与历史轨迹?  Laravel如何使用Eloquent进行子查询  JavaScript如何实现路由_前端路由原理是什么  香港网站服务器数量如何影响SEO优化效果?  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  高端智能建站公司优选:品牌定制与SEO优化一站式服务  如何在阿里云部署织梦网站?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  高防服务器如何保障网站安全无虞?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  如何基于云服务器快速搭建个人网站?  英语简历制作免费网站推荐,如何将简历翻译成英文?  MySQL查询结果复制到新表的方法(更新、插入)  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  java ZXing生成二维码及条码实例分享  Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作  ,南京靠谱的征婚网站?  如何在自有机房高效搭建专业网站?  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何在腾讯云服务器上快速搭建个人网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  网站制作价目表怎么做,珍爱网婚介费用多少?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  Laravel如何生成API文档?(Swagger/OpenAPI教程)  在Oracle关闭情况下如何修改spfile的参数  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  JavaScript如何实现音频处理_Web Audio API如何工作?  如何基于云服务器快速搭建网站及云盘系统?  长沙企业网站制作哪家好,长沙水业集团官方网站?  如何实现javascript表单验证_正则表达式有哪些实用技巧  郑州企业网站制作公司,郑州招聘网站有哪些?  简单实现Android文件上传  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  Laravel如何升级到最新版本?(升级指南和步骤)  Laravel如何处理表单验证?(Requests代码示例)  WEB开发之注册页面验证码倒计时代码的实现  如何将凡科建站内容保存为本地文件?  简单实现Android验证码  C++用Dijkstra(迪杰斯特拉)算法求最短路径  如何用花生壳三步快速搭建专属网站?  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  免费视频制作网站,更新又快又好的免费电影网站?  香港服务器租用每月最低只需15元?