ng-content指令可以在组件中嵌入模板代码,方便定制可复用的组件。
比如:页面的header是个通用组件,导航菜单样式已经设定好,只需在header标签内加上菜单内容。
用ng-content标签,将父组件模板中包含的menu标签内容加到指定位置。select属性支持css选择器,如:"#id",".class","[name=value]"等
header组件的模板:
<p> {{title}} </p> <p><input type="checkbox" name="cb" [(ngmodel)]="ischecked" (click)="toggle()" />checkbox <br /></p> <ng-content select="menu"></ng-content>
父组件使用方法:
<app-header #header [title]="title" name="{{name}}" (checkemitter)="oncheckedchange($event)" > <menu> <ul> <li>aa</li> <li>bb</li> <li>cc</li> </ul> </menu> </app-header> <app-header #header2 [title]="title2" name="{{name}}" (checkemitter)="oncheckedchange($event)" ></app-header> <button (click)="header.toggle()">通过本地变量调用子组件方法</button> <button (click)="headertoggle()">通过viewchild调用子组件方法</button>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问, 点击进行留言回复!!
解决三元运算符 报错“SyntaxError: can''t assign to conditional expression”
解决angular 使用原生拖拽页面卡顿及表单控件输入延迟问题
使用 Angular RouteReuseStrategy 缓存(路由)组件的实例代码
分享Angular http interceptors 拦截器使用(推荐)
网友评论