用于CRUD应用程序的网格。 我有一些数据显示在ag-grid表中
我使用了ag-grid单元格渲染器来渲染该按钮
import React, { Component } from 'react';
export default class DeleteButton extends Component {
render() {
return (
<span><button onClick={}>X</button></span>
);
}
}
我以这样的组件状态存储数据和列defs
this.state = {
rewData : [
{make: "Toyota", model: "Celica", qty:12, price: 35000, test:"", image:""},
{make: "Ford", model: "Mondeo", qty:1, price: 32000, test:"", image:""},
{make: "Porsche", model: "Boxter", qty:8, price: 72000, test:"", image:""},
{make: "Porsche", model: "Boxter", qty:8, price: 72000, test:"", image:""}
],
columnDefs:[
{"headerName":"Make","field":"make","cellEditor":"textCellEditor","cellEditorParams":{"required":true}},
{"headerName":"Model","field":"model","cellEditor":"multiLineTextCellEditor","cellEditorParams":{"required":true}},
{"headerName":"Qty","field":"qty","cellEditor":"numericCellEditor","cellEditorParams":{"required":true}},
{"headerName":"Price","field":"price","cellEditor":"numericCellEditor","cellRenderer":"currencyCellRenderer","cellEditorParams":{"required":true}},
{"headerName":"test","field":"test","cellEditor":"manyToOneCellEditor","cellEditorParams":{"model":"account","host":"http://localhost:8282","fieldAsLabel":"name","fieldAsValue":"id","required":true}},
{"headerName":"image","field":"image","cellEditor":"fileUploadCellEditor","cellRenderer":"imageCellRenderer","cellEditorParams":{"required":true}},
{"headerName":"Delete","cellRenderer":"deleteButton"}
]
}
并将其传递到ag-grid的rowData道具中:
<AgGridReact
defaultColDef={defaultColDef}
columnDefs={this.state.columnDefs}
rowData={this.state.rowData}
onGridReady={this.onGridReady}
onCellValueChanged={this.handleChange}
frameworkComponents={this.state.frameworkComponents}
singleClickEdit={true}
stopEditingWhenGridLosesFocus={true}
reactNext={true}
/>
当我单击删除按钮时,我想删除相应的行以及其他诸如验证或向用户显示通知等内容
我如何使该按钮可以更改rowData的状态?
我在哪里放置更改rowData状态的方法?
答案 0 :(得分:0)
this.gridApi.updateRowData
将在对象数组中收到rowNode
export default class DeleteButton extends Component {
render() {
return (
<span><button onClick={() => this.buttonClick(this.props.node)}>X</button></span>
);
}
}
buttonClick = (e) => {
*// e is getting the current node (Row Node)*
this.setState({
visible:true
})
let deletedRow = this.props.node.data;
e.gridApi.updateRowData({ remove: [deletedRow] }) // It will update the row
};