如何使用ag网格在前端加载4000条记录

时间:2017-10-17 09:24:39

标签: ag-grid

即时通讯使用ag网格rowmodeltype是企业(服务器端),因为如果我加载所有记录,api响应花费的时间差不多2-3分钟,所以使用服务器端分页

  1. 列标签分组ag网格没有提供任何后端样本来处理。
  2. 如果我们在客户端加载所有记录,那么所有ag网格功能都可以正常工作,那么有没有办法以30列和40000条记录更快地加载10mb大小的数据。

1 个答案:

答案 0 :(得分:0)

大多数瓶颈发生在后端(数据库检索)。 为了减少缓慢的影响,你可以采用我使用过的方法。

  1. 增强后端api以支持服务器端分页呼叫
  2. 重新加载ajax调用以进行小规模调用(例如前400行)。
  3. 完成首次加载后,请检查是否还有其他记录。如果是,请设置递归加载直到完成。
  4. 现在,用户将会看到'那些前400行,而它仍然加载剩余的3600行。您需要在此处显示加载图标以显示进度。

    下面是一个加载此代码的代码示例。

    var myList = [];
    
    var loadDataFunc = function( start, limit ) {
            _self.Status.IsLoading = true;
    
            $http
                .get( DataUrl + "?start=" + start + "&limit=" + limit)
                .then(function(response){
    
                    if( response && response.data && response.data.List) {
                        if( response.data.Total > 0 ) {
                            for( var z = 0; z < response.data.List.length; z++ ) {
                                myList.push(response.data.List[z]);
                            }
    
                            var currentItemsLoaded = start + response.data.List.length;
                            if( currentItemsLoaded < response.data.Total ) {
                                //means we still have pending to load, then we load again!
                                setTimeout(function(){
                                    loadDataFunc(currentItemsLoaded, limit);
                                }, 500);
                            }else {
                                //If it reaches here, it means we have completed loading
                                _self.Status.IsLoading = false;
                                _self.Status.IsLoaded = true;
                            }
                            BindDataToGrid();
                        } else {
                            _self.Status.IsLoading = false;
                            _self.Status.IsLoaded = true;   
                            if( start === 0 ) {
                                BindDataToGrid();
                            }
                        }
                    }
                    else {
                        _self.Status.IsLoading = false;
                        _self.Status.IsLoaded = true;
                    }
                })
                .catch(function(response){
                    _self.Status.IsLoading = false;
                    //error!
                });
        };      
    
        function BindDataToGrid () {
            setTimeout(function(){                  
              grid.api.setRowData(myList);
            },100);
        };