angular.js - datatable 重新渲染 rerender 能不能不重现请求ajax 数据

查看:289
本文介绍了angular.js - datatable 重新渲染 rerender 能不能不重现请求ajax 数据的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

当配置了 ajax 后,我每次执行rerender后都重新请求数据,导致本来时第三页的,但重新渲染了后变回第一页了,有办法只重新渲染不重新请求ajax数据吗,或重新请求时仍然是第三页

解决方案

datatable我用的比较多,结合你提供的信息

重新当前页的数据

ajax重新获得当前页码的数据

var dt = $('#datatable').DataTable({
    ...
});
dt.ajax.reload(null, false); //记得这两个参数

F5刷新页面

F5之后,仍然保持当前的页码,这需要用一点技巧,使用localhost.hash保存页码、排序等数据

条件:

  1. 加载 Hash 的便捷操作工具: https://github.com/cowboy/jquery-bbq

  2. 如下操作

var _config = {
    displayStart: 0, 
    pageLength: 10,
    order: [],
    drawCallback: function( settings ) {
        //绘制好之后,将状态写到Hash上面,翻页,排序的时候也会保持状态
        var config = {
            displayStart: settings._iDisplayStart,
            pageLength: settings._iDisplayLength,
            search: {search: settings.oPreviousSearch.sSearch},
            order: []
        };
        settings.aLastSort.forEach(function(v){
            config.order.push([v.col, v.dir]);
        });
        $.bbq.pushState(config);
    },
    .....
};
var config = $.bbq.getState();
config = $.extend(true, _config, config);

var dt = $('#datatable').DataTable(config);


这篇关于angular.js - datatable 重新渲染 rerender 能不能不重现请求ajax 数据的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆