浅谈Angular模板指令:ng-template和ng-container的用法

本篇文章带大家简单了解一下Angular模板的ng-template和ng-container指令,介绍一下ng-template和ng-container指令使用方法

ng-template指令简介

ng-template是一个 Angular 结构型指令,用来渲染 HTML。 它永远不会直接显示出来。 事实上,在渲染视图之前,Angular 会把 ng-template 及其内容替换为一个注释。【相关教程推荐:《angular教程》】

如果没有使用结构型指令,而仅仅把一些别的元素包装进 ng-template 中,那些元素就是不可见的。

像*ngFor、 *ngIf这些指令Angular内部会把这些属性翻译成一个 元素 并用它来包裹宿主元素。

ng-container指令简介

为了避免创建额外的div,我们可以改用ng-container,它是一个分组元素,但它不会污染样式或元素布局,因为 Angular 压根不会把它放进 DOM 中。ng-container 是一个由 Angular 解析器负责识别处理的语法元素。 它不是一个指令、组件、类或接口,更像是 JavaScript 中 if 块中的花括号。

ng-container用法

用法一(最基础的用法

我们在一个列表循环里有写时候有一些判断要完成,我们知道angular的结构指令是不允许两个同时存在的,这个时候如果我们又不想增加多余的div就可以用ng-container

<ul>
    <ng-container *ngFor=let item of list>
        <li *ngIf=item.context>{{item.context}}</li>
    </ng-container>
</ul>

用法二(结合ngSwitch一起使用)

<ng-container [ngSwitch]=type>
    <ng-container *ngSwitchCase='title'>标题</ng-container>
    <ng-container *ngSwitchCase='text'>内容</ng-container>
    <ng-container *ngSwitchDefault>其他</ng-container>
</ng-container>

当然ngSwitch也可以直接写在html标签上。

用法三(结合ng-template使用)

可以跟template配合使用,将重复的模块内容抽取出来,也可传参给要显示的模板。 比如下面的这个例子,甲方有甲方姓名和介绍,乙方也同样有这些介绍,我们就可以把共同介绍整合出来。

<div>
    <!--甲方-->
    <div>
        <div class=left>甲方:</div>
        <div class=right>
            甲方姓名
            <ng-container *ngTemplateOutlet=introduce; context: {data: data.partyA}></ng-container>
            <!--也可以写成这种方式-->
            <!--
            <ng-container [ngTemplateOutlet]=introduce
                [ngTemplateOutletContext]={data: data.partyA}>
            </ng-container>
            [ngTemplateOutlet]也可用在ng-template上
            -->
        </div>
    </div>
    <!--乙方-->
    <div>
        <div class=left>乙方:</div>
        <div class=right>
            乙方姓名
            <ng-container *ngTemplateOutlet=introduce; context: {data: data.partyB}></ng-container>
        </div>
    </div>
    <!--let-data=data就是上面传进来的值-->
    <ng-template #introduce let-data=data>
        <p>合同介绍......</p>
    </ng-template>
</div>

ngTemplateOutlet是定义模板引用和模板的上下文(即ng-template)对象的字符串,这样如果有多个模板引用可以用这种方式 ngTemplateOutletContext是附加到的上下文(即ng-template)对象EmbeddedViewRef。这应该是一个对象,该对象的键可用于本地模板let 声明的绑定。$implicit在上下文(即ng-template)对象中使用键会将其值设置为认值。 ngTemplateOutlet也可用于外部传进来的模板

child.component.html

<ng-template [ngTemplateOutlet]=tplRef [ngTemplateOutletContext]={data: data}></ng-template>

child.component.ts

@input() tplRef: TemplateRef<any>

ng-template用法

用法

结合*ngIf使用,这样可以不用加两次不同判断条件,可以在html里直接使用if else语句

<div *ngIf=text; else noData>{{text}}</div>
<ng-template #noData>
    <div class=gary>暂无数据</div>
</ng-template>

用法

页面里使用antd的modalService创建对话框时,可以模板写在html里面,通过引用加载过来放到modal的nzContent里(说的有点乱了,看代码吧)

<ng-tempalte #content>xxxxxxx</ng-template>
export class AppComponent implements OnInit {
    // 引入模板
     @ViewChild('content') contentTpl: TemplateRef<any>;
    ngOnInit() {
        this.modalService.create({
            nzTitle: '标题',
            nzContent: this.contentTpl
        })
    }
}

用法

以模板的形式,作为一个输入变量传给组件,这样我们就可以在用这个组件时写成自己想要的内容 比如我们写个共用的暂无数据的组件,一般只用传text文字就可以有些特殊的时候我们可能需要一些新增按钮。

empty.component.html

<div>
    <img src=/>
    <div>
        <ng-container [ngSwitch]=true>
            <ng-container *ngSwitchCase=istemplate(text)
                [ngTemplateOutlet]=text
            ></ng-container>
        </ng-container>
        {{text || ''}}
    </div>
</div>

empty.component.ts

export class EmptyComponent {
    @input() text: TemplateRef<any>
  istemplate(text: any) {
      return text instanceof TemplateRef;
  }
}

总结,都是一些最基础的用法,现在所了解的就这些用法,如果有知道更多的欢迎大家补充。

更多编程相关知识,请访问:编程视频!!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)