大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要讲解了“Angular模板中ng-template和ng-container指令的用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Angular模板中ng-template和ng-container指令的用法”吧!
我们提供的服务有:网站设计、成都网站制作、微信公众号开发、网站优化、网站认证、山南ssl等。为成百上千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的山南网站制作公司
ng-template是一个 Angular 结构型指令,用来渲染 HTML。 它永远不会直接显示出来。 事实上,在渲染视图之前,Angular 会把 ng-template 及其内容替换为一个注释。
如果没有使用结构型指令,而仅仅把一些别的元素包装进 ng-template 中,那些元素就是不可见的。
像*ngFor、 *ngIf这些指令Angular内部会把这些属性翻译成一个 元素 并用它来包裹宿主元素。
为了避免创建额外的div,我们可以改用ng-container,它是一个分组元素,但它不会污染样式或元素布局,因为 Angular 压根不会把它放进 DOM 中。ng-container 是一个由 Angular 解析器负责识别处理的语法元素。 它不是一个指令、组件、类或接口,更像是 JavaScript 中 if 块中的花括号。
用法一(最基础的用法)
我们在一个列表循环里有写时候有一些判断要完成,我们知道angular的结构指令是不允许两个同时存在的,这个时候如果我们又不想增加多余的div就可以用ng-container
用法二(结合ngSwitch一起使用)
标题 内容 其他
当然ngSwitch也可以直接写在html标签上。
用法三(结合ng-template使用)
可以跟template配合使用,将重复的模块内容抽取出来,也可传参给要显示的模板。 比如下面的这个例子,甲方有甲方姓名和介绍,乙方也同样有这些介绍,我们就可以把共同介绍整合出来。
甲方:甲方姓名 乙方:乙方姓名合同介绍......
ngTemplateOutlet是定义模板引用和模板的上下文(即ng-template)对象的字符串,这样如果有多个模板引用可以用这种方式 ngTemplateOutletContext是附加到的上下文(即ng-template)对象EmbeddedViewRef。这应该是一个对象,该对象的键可用于本地模板let 声明的绑定。$implicit在上下文(即ng-template)对象中使用键会将其值设置为默认值。 ngTemplateOutlet也可用于外部传进来的模板
child.component.html
child.component.ts
@Input() tplRef: TemplateRef
用法一
结合*ngIf使用,这样可以不用加两次不同判断条件,可以在html里直接使用if else语句
{{text}} 暂无数据
用法二
页面里使用antd的modalService创建对话框时,可以模板写在html里面,通过引用加载过来放到modal的nzContent里(说的有点乱了,看代码吧)
xxxxxxx
export class AppComponent implements OnInit { // 引入模板 @ViewChild('content') contentTpl: TemplateRef; ngOnInit() { this.modalService.create({ nzTitle: '标题', nzContent: this.contentTpl }) } }
用法三
以模板的形式,作为一个输入变量传给组件,这样我们就可以在用这个组件时写成自己想要的内容 比如我们写个共用的暂无数据的组件,一般只用传text文字就可以有些特殊的时候我们可能需要一些新增按钮。
empty.component.html
{{text || ''}}
empty.component.ts
export class EmptyComponent { @Input() text: TemplateRefisTemplate(text: any) { return text instanceof TemplateRef; } }
总结,都是一些最基础的用法,现在所了解的就这些用法,如果有知道更多的欢迎大家补充。
感谢各位的阅读,以上就是“Angular模板中ng-template和ng-container指令的用法”的内容了,经过本文的学习后,相信大家对Angular模板中ng-template和ng-container指令的用法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!