详解Angular 4.x NgTemplateOutlet


Posted in Javascript onMay 24, 2017

该指令用于基于已有的 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 是等价的。

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

Javascript 相关文章推荐
jquery中获得$.ajax()事件返回的值并添加事件的方法
Apr 15 Javascript
javascript的document.referrer浏览器支持、失效情况总结
Jul 18 Javascript
一款基于jQuery的图片场景标注提示弹窗特效
Jan 05 Javascript
bootstrap提示标签、提示框实现代码
Dec 28 Javascript
基于JavaScript实现五子棋游戏
Aug 26 Javascript
Vue实现底部侧边工具栏的实例代码
Sep 03 Javascript
JS module的导出和导入的实现代码
Feb 25 Javascript
vue-next/runtime-core 源码阅读指南详解
Oct 25 Javascript
vue-router的钩子函数用法实例分析
Oct 26 Javascript
Vuejs中的watch实例详解(监听者)
Jan 05 Javascript
js实现全选和全不选
Jul 28 Javascript
详解Node.JS模块 process
Aug 31 Javascript
javascript简单写的判断电话号码实例
May 24 #Javascript
Angular2搜索和重置按钮过场动画
May 24 #Javascript
深入理解react-router@4.0 使用和源码解析
May 23 #Javascript
angularjs中ng-bind-html的用法总结
May 23 #Javascript
vue.js实现价格格式化的方法
May 23 #Javascript
js编写选项卡效果
May 23 #Javascript
jQuery日期范围选择器附源码下载
May 23 #jQuery
You might like
同一空间绑定多个域名而实现访问不同页面的PHP代码
2006/12/06 PHP
PHP实现用户认证及管理完全源码
2007/03/11 PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
2015/07/31 PHP
Jquery Ajax.ashx 高效分页实现代码
2009/10/20 Javascript
javascript实现瀑布流动态加载图片原理
2016/08/12 Javascript
react.js 翻页插件实例代码
2017/01/19 Javascript
Vue实现购物车功能
2017/04/27 Javascript
protractor的安装与基本使用教程
2017/07/07 Javascript
详解Axios 如何取消已发送的请求
2018/10/20 Javascript
vue 实现左右拖拽元素并且不超过他的父元素的宽度
2018/11/30 Javascript
在Layui中实现开关按钮的效果实例
2019/09/29 Javascript
JS实现点击下拉列表文本框中出现对应的网址,点击跳转按钮实现跳转
2019/11/25 Javascript
[45:18]2018DOTA2亚洲邀请赛 4.3 突围赛 Optic vs iG 第一场
2018/04/04 DOTA
[01:07:34]DOTA2-DPC中国联赛定级赛 RNG vs Aster BO3第二场 1月9日
2021/03/11 DOTA
python动态加载变量示例分享
2014/02/17 Python
深入学习python的yield和generator
2016/03/10 Python
Python 爬虫多线程详解及实例代码
2016/10/08 Python
Windows下Anaconda2安装NLTK教程
2018/09/19 Python
django使用xadmin的全局配置详解
2019/11/15 Python
Pyorch之numpy与torch之间相互转换方式
2019/12/31 Python
python wav模块获取采样率 采样点声道量化位数(实例代码)
2020/01/22 Python
Python telnet登陆功能实现代码
2020/04/16 Python
Python实现JS解密并爬取某音漫客网站
2020/10/23 Python
eDreams巴西:廉价机票,酒店优惠和度假套餐
2017/04/14 全球购物
阿根廷首家户外用品制造商和经销商:Montagne
2018/02/12 全球购物
澳大利高级泳装品牌:Bondi Born
2018/05/23 全球购物
.NET初级开发工程师面试题
2014/04/18 面试题
UNIX文件类型
2013/08/29 面试题
市场开发与营销专业求职信
2013/12/31 职场文书
驾驶员岗位职责
2014/01/29 职场文书
镇党委书记群众路线整改措施思想汇报
2014/10/13 职场文书
党的群众路线教育实践活动批评与自我批评发言稿
2014/10/16 职场文书
专家推荐信怎么写
2015/03/25 职场文书
朋友聚会开场白
2015/06/01 职场文书
详解Python自动化之文件自动化处理
2021/06/21 Python
从零开始在Centos7上部署SpringBoot项目
2022/04/07 Servers