在 ag-grid 中实现一个按钮

Alo*_*lon 5 ag-grid angular

我试图从这个ag-grid示例中学习,以便在网格的每一行中创建一个删除按钮。上述示例有效,但我的代码无效,我不知道为什么。

我附上了我的代码,希望有人能帮助我。

home.component.ts:

@Component({
  selector: 'home',
  providers: [
    Title
  ],
  styleUrls: [ './home.component.css' ],
  templateUrl: './home.component.html'
})
export class HomeComponent implements OnInit {
  private items: Item[] = [];
  private gridOptions:GridOptions;
  private columnDefs = [];

  constructor(
    private itemsService: ItemsService
  ) {
    this.gridOptions = {};
    this.columnDefs = this.createColumnDefs();
  }

  remove() {
    alert("yey!")
  }

  ngOnInit(){
    this.itemsService
      .getAll()
      .subscribe(result => {
        this.items = result;
      });
  }

  private createColumnDefs() {
    return [
      {
        headerName: "Foo",
        field: "foo",
        width: 100,
      },
      {
        headerName: "Bar",
        field: "bar",
        width: 100,
      },
      {
        headerName: "",
        field: "_id",
        cellRendererFramework: RemoveButton,
        colId: "params",
        width: 100
      },
    ];
  }
}
Run Code Online (Sandbox Code Playgroud)

home.component.html:

<div>
      <ag-grid-angular #agGrid style="width: 602px; height: 350px;" class="ag-fresh"
                       [gridOptions]="gridOptions"
                       [columnDefs]="columnDefs"
                       [rowData]="items">
      </ag-grid-angular>
  </div>
Run Code Online (Sandbox Code Playgroud)

删除按钮.ts:

@Component({
  selector: 'remove-button',
  template: `<span><button style="height: 20px" (click)="remove()">X</button></span>`
})
export class RemoveButton implements ICellRendererAngularComp {
  public params: any;

  agInit(params: any): void {
    this.params = params;
  }

  public remove() {
    this.params.context.componentParent.remove();
  }
}
Run Code Online (Sandbox Code Playgroud)

网格显示所有数据,但单击按钮会产生以下错误:

ERROR TypeError: Cannot read property 'componentParent' of undefined
    at RemoveButton.webpackJsonpac__name_.453.RemoveButton.remove
Run Code Online (Sandbox Code Playgroud)

contextparams是不确定的。

如果需要任何进一步的代码或信息,请告诉我。

Alo*_*lon 12

我已经解决了我的问题。显然context是未定义的,因为我没有定义它。定义里面的上下文gridOptions已经解决了:

this.gridOptions ={
      context: {
        componentParent: this
      }
    };
Run Code Online (Sandbox Code Playgroud)

  • 文档没有提到这一点,就像其他文档一样,总是缺少关键方面。我也有同样的问题,不明白为什么。 (2认同)