11

我正在使用Angular UI Grid来显示一些数据。启用和初始化排序以及选择单行:

vm.gridOptions = {
    enableSorting: true,
    enableRowSelection: true,
    multiSelect: false,
    noUnselect: true,
    columnDefs: [
        { name: '#', field: 'ID' },
        { name: 'Name', field: 'CODE', sort: { direction: 'asc', priority: 1 } },
        { name: 'Comment', field: 'DESCR' },
    ],
    data: []
};

我可以选择一行,并且这些行按配置的“名称”列按升序排序。

UI Grid Tutorial 210中所示,我添加了在我的数据加载并添加到网格后自动选择第一项的逻辑:

datacontext.getAllGcTab(vm.filter).then(function (result) {
    vm.gridOptions.data = result.results;
    vm.gridApi.selection.selectRow(vm.gridOptions.data[0]);
});

但是此代码正在选择未排序数据的第一项。我的网格中大约有 500 个项目,数量不多且性能良好,但在这种情况下,所选项目位于直线下方且不可见。

是否有任何选项可以直接访问 UI Grid 的行或排序数据?

我知道外部排序可以解决这个问题,因为那时我会将已经排序的数据分配给网格。但这在我看来是不必要的开销......

4

1 回答 1

12

$scope.gridApi.core.getVisibleRows()返回当前排序/过滤顺序的行数组。

于 2015-04-16T17:21:00.333 回答