Angular借助指令传递模板

上一篇中使用 @Host() @Optional() public hc: HelloComponent感觉不够优雅,也不符合正常数据传递流程。下面是改造后的实现逻辑。
在HelloComponent中使用ContentChildren获取所有HelloDirective。
@Component({
    selector: 'hs-hello',
    template: `
        <div>
            <ng-container *ngFor="let helloDirective of helloTemplates">
                <p>this is hello-for</p>
                <ng-container *ngTemplateOutlet="helloDirective.template"></ng-container>
            </ng-container>
        </div>
    `
})
export class HelloComponent {
    @ContentChildren(HelloDirective) helloTemplates: QueryList<HelloDirective>;
}
HelloDirective中将template向外暴露,借助指令传递TemplateRef,同时指令也起到了分类模板的作用
@Directive({
    selector: '[hsHello]'
})
export class HelloDirective {

    constructor(
        public template: TemplateRef<any>
    ) {}
}
示例

<hs-hello>
    <ng-template hsHello>
        <p>this is hello-1</p>
    </ng-template>

    <ng-template hsHello>
        <p>this is hello-2</p>
    </ng-template>

    <ng-template hsHello>
        <p>this is hello-3</p>
    </ng-template>
</hs-hello>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值