Angular指令:将第一个指令的输出作为第二个指令的模板输入传递
创始人
2024-10-31 00:00:24
0

要将第一个指令的输出作为第二个指令的模板输入传递,可以使用Angular的@Input装饰器和动态组件来实现。以下是一个示例代码:

首先,创建第一个指令,将其命名为FirstDirective:

import { Directive, ElementRef } from '@angular/core';

@Directive({
  selector: '[firstDirective]'
})
export class FirstDirective {
  constructor(private elementRef: ElementRef) { }

  getText(): string {
    return this.elementRef.nativeElement.innerText;
  }
}

然后,创建第二个指令,将其命名为SecondDirective,并在其模板中使用第一个指令的输出:

import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';

@Directive({
  selector: '[secondDirective]'
})
export class SecondDirective {
  @Input() secondDirectiveTemplate: TemplateRef;

  constructor(private viewContainerRef: ViewContainerRef) { }

  ngOnInit() {
    const text = this.secondDirectiveTemplate.createEmbeddedView(null).rootNodes[0].innerText;
    console.log(text); // 输出第一个指令的输出

    // 将第一个指令的输出作为模板输入传递给第二个指令
    this.viewContainerRef.createEmbeddedView(this.secondDirectiveTemplate, { text });
  }
}

最后,在组件的模板中使用这两个指令:

这是第一个指令的输出
{{ text }}

这样,第二个指令就可以获取第一个指令的输出,并将其作为模板输入传递给自己的模板中。

相关内容

热门资讯

黑科技挂!德州竞技联盟辅助(w... 您好,wepoke透明黑科技这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多...
黑科技计算!菠萝德州辅助神器(... 黑科技计算!菠萝德州辅助神器(aapoker辅助工具ai)原生是有挂(有挂透视)-哔哩哔哩是一款可以...
黑科技教学!wepoke软件规... 黑科技教学!wepoke软件规律(wepoke智能ai)本来是真的有挂(有挂分析)-哔哩哔哩1、we...
黑科技线上!哈糖大菠萝洗牌(德... 黑科技线上!哈糖大菠萝洗牌(德扑ai智能机器人线上代打)原来真的是有挂(有挂教程)-哔哩哔哩1、实时...
黑科技免费!wepoke到底有... 1、黑科技免费!wepoke到底有挂(德州ai软件购买)其实是真的有挂(有挂秘籍)-哔哩哔哩;该软件...
黑科技ai!扑克时间有后台控制... 黑科技ai!扑克时间有后台控制(微扑克如何让系统发好牌)本来是真的有挂(了解有挂)-哔哩哔哩(1)黑...
黑科技系统!wpk辅助器安装(... 黑科技系统!wpk辅助器安装(wpk最新黑科技)本然真的是有挂(有挂辅助)-哔哩哔哩1)wpk最新黑...
黑科技存在!微扑克辅助插件挂(... 黑科技存在!微扑克辅助插件挂(德扑ai机器人软件开发)切实是有挂(有挂存在)-哔哩哔哩您好,德扑ai...
黑科技线上!wepoke插件(... 1、黑科技线上!wepoke插件(德扑ai机器人软件开发)原本是真的有挂(有人有挂)-哔哩哔哩;代表...
黑科技数据!鱼扑克软件辅助(德... 黑科技数据!鱼扑克软件辅助(德扑ai智能机器人)确实存在有挂(有挂辅助)-哔哩哔哩(1)黑科技数据!...