2

我有角度数据表配置,效果很好。我的配置看起来像

  vm.dtOptions = DTOptionsBuilder.newOptions().
            withPaginationType('full_numbers').
            //withOption('ajax', {
            //    url: 'rest/get/'+entityName,
            //    type: 'GET'
            //}).
            withOption('serverSide', true).
            withOption('ajax', function(data, callback, settings) {
                    EntityManager.get({entity:entityName,action:'get',start:data.start,length:data.length}).$promise.then(function(response) {
                    console.log('response');
                    console.log(response);
                    vm.objectList = response.data;

                    callback({
                        recordsTotal:    response.recordsTotal,
                        recordsFiltered: response.recordsFiltered,
                        data: response.data
                    });

                });
            }).
            withDataProp('data').
            withOption('processing', true).
            withOption('bFilter', false).
            withOption('bSort', false).
            withOption("aaSorting", []).
            withDisplayLength(10);

但我也有更新数据的过滤功能,recordsTotal因此应该重新渲染分页 - 必须修改最后一个按钮编号。但它不会发生。有没有办法打电话

 callback({
      recordsTotal:    response.recordsTotal,
      recordsFiltered: response.recordsFiltered,
      data: response.data
 });

从控制器?什么对象和什么方法更新分页?

4

1 回答 1

2

好的,最后我找到了解决方案。首先,在标记中添加 dt-instance:

 <div ng-controller="DataTableController as listTable" ng-init="init('informsystem')">
   <table datatable="" dt-options="listTable.dtOptions" dt-instance="listTable.dtInstance" class="row-border hover">

在控制器中声明 dtInstance 变量并对其进行初始化。此外,获取所有 ajax 回调逻辑以分离函数并将其传递到 dtoptions 和过滤器中:

 var vm = this;
 vm.dtInstance = {}; //MUST BE INITIALIZED! DON'T FORGET vm.(this) before varName

        var ajaxCallback = function(data, callback, settings) {
            $scope.filter.start = data.start;
            $scope.filter.length = data.length;
            console.log($scope.filter);
            EntityManager.get($scope.filter).$promise.then(function(response) {
                console.log('response');
                console.log(response);
                vm.objectList = response.data;

                callback({
                    recordsTotal:    response.recordsTotal,
                    recordsFiltered: response.recordsFiltered,
                    data: response.data
                });

            });
        };

在配置中使用 ajaxCallback:

   ....withOption('ajax', ajaxCallback ).....

在 doFilter/doSearch 中:

  $scope.doFilter = function () {
            console.log(vm.dtInstance);
            vm.dtInstance.changeData(ajaxCallback);
        };

$scope.filter 在 init 中填充了 $resource 的公共参数,并且在回调中添加了 start 和 length(偏移量)。此外,过滤器包含来自通过ng-model.

于 2015-11-04T04:07:08.310 回答