AG-Grid默认不会在数据源中重新排序行。要实现排序功能,需要使用gridApi.setRowData()方法重新设置数据源并传递一个排序器。以下是使用AG-Grid重新排序数据源的示例代码:
// 定义原始数据
var rowData = [
{athlete: 'Michael Phelps', country: 'United States', year: '2008', gold: '8'},
{athlete: 'Michael Phelps', country: 'United States', year: '2004', gold: '6'},
{athlete: 'Natalie Coughlin', country: 'United States', year: '2008', gold: '1'},
{athlete: 'Aleksey Nemov', country: 'Russia', year: '2000', gold: '2'},
{athlete: 'Alicia Coutts', country: 'Australia', year: '2012', gold: '1'}
];
// 定义列定义对象
var columnDefs = [
{headerName: 'Athlete', field: 'athlete'},
{headerName: 'Country', field: 'country'},
{headerName: 'Year', field: 'year'},
{headerName: 'Gold', field: 'gold'}
];
// 定义grid的options
var gridOptions = {
columnDefs: columnDefs,
rowData: rowData
};
// 将grid实例化
var grid = new agGrid.Grid(document.querySelector('#myGrid'), gridOptions);
// 模拟一些数据排序
function sortData(){
var sort = [
{colId: 'gold', sort: 'desc'}
];
gridOptions.api.setRowData(_.sortBy(rowData, sort));
}
// 按钮点击事件
document.querySelector('#sortButton').addEventListener('click', function() {
sortData();
});
在示例中,我们通过调用gridOptions中的api来设置新的rowData,并将通过_.sortBy()函数进行排序的、排序条件数组传递给它。最后,我们在按钮点击事件中调用sortData()函数,以模拟按gold列降序排序数据。
需要注意的是,如果使用时间戳或日期等类型的字段进行排序,则需要使用moment.js或其他类似的库来解析和比较这些值。