angularjs – 角度ui-grid/ng-grid filter更换频繁

我正在尝试使用服务器端排序,服务器端分页和服务器端过滤来实现角度网格.使用ui-grid(不稳定),我添加了ui.grid.paging并使所有内容都运行起来.非常好,对开发人员的称赞.

但是…. $scope.gridApi.core.on.filterChanged被烧成按下每个按键,所以当我在给定名称栏中搜索“帕特里克”,七个事件被解雇和七个得到-请求打我的服务器.更糟糕的是,因为它是一个大组,我过滤,这种操作是相当昂贵的,结果连我你追我赶,像最具体的过滤器获得最快速的结果,触发成功处理的不太具体结果之前.

我想放慢速度,比如“进入后停火”.我是javascript和REST的新手,这是我的第一个真实世界项目.我真的很感激如何处理这个问题的任何想法.这感觉就像一个常见的场景,因此可能会有一些我缺少的标准解决方案或最佳实践.

此致,
帕特里克.

如果你想“全角”,我建议在on.filterChanged事件处理程序中使用$timeout:
if (angular.isDefined($scope.filterTimeout)) {
    $timeout.cancel($scope.filterTimeout);
}
$scope.filterTimeout = $timeout(function () {
    getPage();
},500);

其中500是你想要在每个on.filterChanged事件之前等待到服务器之前的时间(以毫秒为单位),而getPage()是实际进入服务器并检索数据的函数.

不要忘记在控制器的’destroy’事件中取消$timeout:

$scope.$on("$destroy",function (event) {
    if (angular.isDefined($scope.filterTimeout)) {
        $timeout.cancel($scope.filterTimeout);
    }
});

相关文章

ANGULAR.JS:NG-SELECTANDNG-OPTIONSPS:其实看英文文档比看中...
AngularJS中使用Chart.js制折线图与饼图实例  Chart.js 是...
IE浏览器兼容性后续前言 继续尝试解决IE浏览器兼容性问题,...
Angular实现下拉菜单多选写这篇文章时,引用文章地址如下:h...
在AngularJS应用中集成科大讯飞语音输入功能前言 根据项目...
Angular数据更新不及时问题探讨前言 在修复控制角标正确变...