Angular2 ng-content 指令在组件中嵌入内容

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>aali>
      <li>bbli>
      <li>ccli>
    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>

原文链接:https://www.pocketdigi.com/20170204/1557.html

还有篇英文:http://www.tuicool.com/articles/RBvqiai   

你可能感兴趣的:(angular)