遍历通过<ng-template>生成的HTML元素
创始人
2024-12-04 10:00:21
0

要遍历通过 生成的 HTML 元素,你可以使用 Angular 的 @ViewChild 装饰器来获取 ng-template 的引用,然后使用 TemplateRef 类型来访问其内容。

下面是一个示例代码:

HTML 文件:


  
    
{{ item }}

Component 文件:

import { Component, AfterViewInit, ViewChild, TemplateRef, ViewContainerRef } from '@angular/core';

@Component({
  selector: 'app-example',
  templateUrl: './example.component.html',
  styleUrls: ['./example.component.css']
})
export class ExampleComponent implements AfterViewInit {
  @ViewChild('templateRef', { read: TemplateRef }) templateRef: TemplateRef;

  items = ['Item 1', 'Item 2', 'Item 3'];

  constructor(private viewContainerRef: ViewContainerRef) { }

  ngAfterViewInit(): void {
    this.viewContainerRef.createEmbeddedView(this.templateRef);
    const elements = this.viewContainerRef.element.nativeElement.querySelectorAll('div');

    elements.forEach(element => {
      console.log(element.innerText);
    });
  }
}

在上面的示例中,我们使用 @ViewChild 装饰器获取 ng-template 的引用,并将其声明为 TemplateRef 类型。在 ngAfterViewInit 生命周期钩子中,我们使用 createEmbeddedView 方法将模板实例化,并通过 element.nativeElement.querySelectorAll 方法获取生成的 HTML 元素。然后,我们可以遍历这些元素并对它们进行任何操作。

请注意,我们还需要通过构造函数注入 ViewContainerRef 对象,并将其保存在 viewContainerRef 变量中,以便在 ngAfterViewInit 方法中使用。

相关内容

热门资讯

2分钟了解!心悦麻将吹牛有挂是... 2分钟了解!心悦麻将吹牛有挂是真的吗,皮皮麻将怎样提高胜率,2025新版教程(有挂普及)1、玩家可以...
9分钟了解!贵阳哈哈捉鸡麻将有... 9分钟了解!贵阳哈哈捉鸡麻将有挂吗,乐乐川南字牌辅助器,规律教程(有挂规律)1、操作简单,无需注册,...
五分钟了解!掌中乐麻将,波特互... 五分钟了解!掌中乐麻将,波特互娱有挂吗,AA德州教程(有挂规律)1、打开软件启动之后找到中间准星的标...
3分钟了解!边锋斗地主怎么拿好... 3分钟了解!边锋斗地主怎么拿好牌,决战血流怎么设置才能一直赢,黑科技教程(有挂软件)3分钟了解!边锋...
5分钟了解!金州水鱼挂软件,心... 5分钟了解!金州水鱼挂软件,心悦麻将踢坑有挂吗,攻略方法(有挂细节)1、游戏颠覆性的策略玩法,独创攻...
二分钟了解!欢喜麻将app如何... 您好,欢喜麻将app如何提高胜率这款游戏可以开挂的,确实是有挂的,需要了解加微【757446909】...
2分钟了解!网易棋牌可以不,微... 2分钟了解!网易棋牌可以不,微乐斗地主脚本,透明挂教程(有挂实操)1、网易棋牌可以不系统规律教程、网...
三分钟了解!微信决胜麻将免费软... 三分钟了解!微信决胜麻将免费软件,鸿运斗地主有没有挂,新2025版(有挂秘笈)1.微信决胜麻将免费软...
两分钟了解!天天贵阳麻将辅牌器... 您好,畅享徐州麻将有没有挂这款游戏可以开挂的,确实是有挂的,需要了解加微【757446909】很多玩...
8分钟了解!川麻圈辅助器手机版... 8分钟了解!川麻圈辅助器手机版,永州跑胡子辅助工具,第三方教程(有挂总结);1.川麻圈辅助器手机版 ...