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]"等

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM