Datatables学习笔记——服务器模式

1. 如何开启服务器模式

服务器模式即通过ajax通过接口从后端获取数据,也是开发中最常使用的方式。开启服务器模式需要将serverSide选项设置为true,并且在ajax选项中进行相关配置,如获取数据的url、获取数据的方式type等。
最简单的配置代码为:

$('#example').DataTable( {
   //开启服务器模式
    serverSide: true,
   //数据来源(包括处理分页,排序,过滤) ,即url,action,接口,等等
    ajax: '/data-source'
} );

2. DataTables自动发送的参数

开启服务器模式之后,DataTables会发送以下参数到服务器:

DataTables服务器模式下自动发送的参数

3. DataTables服务器端返回的数据格式

后端按以下格式组装好JSON数据返回,表中展示数据放在data中:

DataTables服务器端返回的数据格式

返回数据示例:

{
    "draw": 1,
    "recordsTotal": 57,
    "recordsFiltered": 57,
    "data": [
        [
            "Angelica",
            "Ramos",
            "System Architect",
            "London",
            "9th Oct 09",
            "$2,875"
        ],
        [
            "Ashton",
            "Cox",
            "Technical Author",
            "San Francisco",
            "12th Jan 09",
            "$4,800"
        ],
        ...
    ]
}

4. DataTables中如何传递额外参数到服务器端

实际开发中可能因为后台逻辑的需求,在传递DataTables默认自动发送的参数外还需要发送额外的参数到服务器,这时候就要使用到ajax.data配置项,示例代码如下:

  • 添加一个静态值来提交额外的参数
//添加额外的user_id字段
$('#example').dataTable( {
  "ajax": {
    "url": "data.json",
    "type":"POST",
    "data": {
        "user_id": 451
    }
  }
} );
  • 通过操作数据对象添加数据请求
$('#example').dataTable( {
  "ajax": {
    "url": "data.json",
    "data": function ( d ) {
        d.extra_search = $('#extra').val();
    }
  }
} );
  • 以json格式提交
$('#example').dataTable( {
  "ajax": {
    "url": "data.json",
    "contentType": "application/json",
    "data": function ( d ) {
      return JSON.stringify( d );
    }
  }
} );
  • 动态参数传递
//当你需要多条件查询,你可以调用此方法,动态修改参数传给服务器
function reloadTable() {
    var name = $("#seName").val();
    var admin = $("#seAdmin").val();
    var param = {
        "obj.name": name,
        "obj.admin": admin
    };
    oTable.settings()[0].ajax.data = param;
    oTable.ajax.reload();
}

参考资料:
http://datatables.club/manual/server-side.html
http://datatables.club/reference/option/ajax.html
http://datatables.club/reference/option/ajax.data.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,161评论 19 139
  • 全文链接 第一章 创建一个blog应用第二章 使用高级特性来增强你的blog第三章 扩展你的blog应用第四章上 ...
    夜夜月阅读 12,982评论 37 34
  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 8,706评论 0 7
  • 每个人都有 自己的小秘密 在未知的城市里 有一个独属自己的地方 可以让自己孤独、悲伤 偶尔在那落下眼泪 抬手拭去 ...
    烟酒醉余生阅读 1,792评论 2 3
  • 照顾好你自己,因为在陌生的城市里,没人会关心你过得怎么样
    孑犭刂阅读 472评论 0 0

友情链接更多精彩内容