首页 > 解决方案 > 具有动态函数调用的 ngFor

问题描述

我有一个名为“Action”的对象数组。每个动作都有 2 个参数:函数名和一个布尔值(现在不重要)。

let  actionsArray: Action[] = [{name:"save",enabled:true},{name:"describe",enabled:true},{name:"delete",enabled:true}]

然后我使用 ngFor 来显示函数列表。我想要做的是将每个动作的“点击”事件动态绑定到它的功能。

<li *ngFor="let action of actionsArray">
        <button (click) ="this[action.name]()"> {{action.name}} </button>
</li>

我尝试了很多方法都没有成功。

标签: angulartypescript

解决方案


我用你的代码创建了笔,它可以工作。我还添加了另一种switch/case方法。

@Component({
  selector: 'my-app',
  template: `
    <li *ngFor="let action of actionsArray">
        <button (click) ="[action.name]()"> {{action.name}} </button>
        <button (click) ="callAction(action.name)"> {{action.name}} </button>
    </li>
  `
})
class AppComponent {  
  actionsArray: {name: string, enabled: boolean}[] = [{name:"save",enabled:true},{name:"describe",enabled:true},{name:"delete",enabled:true}]

  callAction(actionName: string) {
    switch(actionName){
      case 'save' : return this.save();
      case 'describe' : return this.describe();
      case 'delete' : return this.delete();
    }
  }

  save() {
    alert('save');
  }

  describe() {
    alert('describe');
  }

  delete() {
    alert('delete');
  }
}

推荐阅读