首页 > 代码库 > Angular2 ng-content 在组件中嵌入内容
Angular2 ng-content 在组件中嵌入内容
ng-content指令可以在组件中嵌入模板代码,方便定制可复用的组件。
比如:页面的header是个通用组件,导航菜单样式已经设定好,只需在header标签内加上菜单内容。
源码以前文为基础。
父组件使用方法:
<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>
这样的结构可谓清晰明了。这里只为演示ng-content的功能,如果是真正开发过程中,可以定制li
成一个菜单按钮,更清晰。
header组件的模板:
<p>
{{title}}
</p>
<p><input type="checkbox" name="cb" [(ngModel)]="isChecked" (click)="toggle()" />Checkbox <br /></p>
<ng-content select="menu"></ng-content>
用ng-content标签,将父组件模板中包含的menu标签内容加到指定位置。select属性支持css选择器,如:"#id",".class","[name=value]"等
Angular2 ng-content 在组件中嵌入内容
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。