Angular如何将点击事件处理程序添加到动态添加的内容
创始人
2024-10-29 07:00:50
0

在Angular中,可以使用事件绑定和动态组件来将点击事件处理程序添加到动态添加的内容。以下是一个示例解决方法:

首先,在父组件中,使用@ViewChild装饰器来引用动态组件的实例。然后,在需要动态添加内容的地方,使用动态组件的createComponent方法来创建动态组件实例。最后,通过事件绑定将点击事件处理程序添加到动态组件实例上。

父组件的代码示例:

import { Component, ViewChild, ViewContainerRef, ComponentFactoryResolver } from '@angular/core';
import { DynamicComponent } from './dynamic.component';

@Component({
  selector: 'app-parent',
  template: `
    
`, }) export class ParentComponent { @ViewChild('container', { read: ViewContainerRef }) container: ViewContainerRef; constructor(private componentFactoryResolver: ComponentFactoryResolver) {} addDynamicComponent() { const dynamicComponentFactory = this.componentFactoryResolver.resolveComponentFactory(DynamicComponent); const dynamicComponentRef = this.container.createComponent(dynamicComponentFactory); dynamicComponentRef.instance.onClick.subscribe(() => { console.log('Dynamic component clicked!'); }); } }

动态组件的代码示例:

import { Component, Output, EventEmitter } from '@angular/core';

@Component({
  selector: 'app-dynamic',
  template: `
    
  `,
})
export class DynamicComponent {
  @Output() onClick = new EventEmitter();

  handleClick() {
    this.onClick.emit();
  }
}

在上述示例中,ParentComponent使用@ViewChild装饰器引用了container元素,这是一个ViewContainerRef类型的实例。然后,当点击“Add Dynamic Component”按钮时,通过调用createComponent方法创建了一个动态组件实例,并将其添加到container中。通过订阅dynamicComponentRef.instance.onClick事件,可以将点击事件处理程序添加到动态组件的onClick输出属性上。

当点击动态组件中的“Click me”按钮时,handleClick方法会触发onClick事件,并通过this.onClick.emit()将事件发送到父组件。在父组件中,可以通过订阅dynamicComponentRef.instance.onClick事件来捕获并处理该事件。

相关内容

热门资讯

玩家必看科普!来玩德州破解器,... 玩家必看科普!来玩德州破解器,德州局透视脚本,AI教程(有挂神器);致您一封信;亲爱德州局透视脚本玩...
专业讨论!wepoker透视脚... 1、专业讨论!wepoker透视脚本免费下载,拱趴大菠萝机器人,普及教程(有挂攻略)(UU poke...
玩家必看科普!wepoker新... 玩家必看科普!wepoker新号好一点吗,epoker透视底牌,爆料教程(有挂教程);1分钟了解详细...
一秒答解!智星德州可以透视吗,... 一秒答解!智星德州可以透视吗,we poker插件,细节方法(有挂技巧);实战中需综合运用上述技巧,...
玩家必看教程!hhpoker免... 玩家必看教程!hhpoker免费透视脚本,poker辅助器免费安装,wpk教程(有挂透明);玩家必备...
重大通报!pokemmo免费脚... 重大通报!pokemmo免费脚本,德州hhpoker是真的吗,力荐教程(有挂方法)是一款可以让一直输...
实测教程!约局吧如何查看是否有... 实测教程!约局吧如何查看是否有挂,智星菠萝可以辅助吗,wepoke教程(有挂软件)准备好在约局吧如何...
重大通报!epoker底牌透视... 重大通报!epoker底牌透视,wepoker有用吗,存在挂教程(有挂透明),支持语音通讯、好友开房...
必备科技!pokerworld... 必备科技!pokerworld破解版下载,wepoker开脚本视频,曝光教程(有挂方法);支持多人共...
推荐几款新版!德州私人局怎么透... 推荐几款新版!德州私人局怎么透视,pokemmo手机辅助软件,系统教程(有挂透明)是一款可以让一直输...