插件介绍: DataTables 表格分页

官网: 
英文:https://datatables.net/ 
中文:http://www.datatables.club/


引入文件(结合bootstrap样式):

        css:
            <link href="statics/css/dataTable/dataTables.bootstrap.min.css" type="text/css" rel="stylesheet">
        js:
            <script src="statics/js/dataTable/jquery.dataTables.min.js" type="text/javascript"></script>
            <script src="statics/js/dataTable/dataTables.bootstrap.min.js" type="text/javascript"></script>
 
 
  • 1
  • 2
  • 3
  • 4
  • 5

用法: 
HTML(以本人项目为例):

<table class="table table-bordered table-hover table-striped" id="dutyListTable">
                            <thead>
                            <tr>
                                <th>选择</th>
                                <th>实际值班人</th>
                                <th>值班日期</th>
                                <th>班次类别</th>
                            </tr>
                            </thead>
                            <tbody id="rewardBody">

                            </tbody>
                        </table>
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

JS(相关配置项):

  var dutyTable =  $("#dutyListTable").dataTable({

        "destroy" : true,       //销毁表格对象
        "aLengthMenu":[5,10],  //用户可自选每页展示数量 5条或10条
        "searching":false,//禁用搜索(搜索框)
        "lengthChange":true,
        "paging": true,//开启表格分页
        "bProcessing" : true,
        "bServerSide" : true,
        "bAutoWidth" : false,
//                  "sort" : "position",
        "deferRender":true,//延迟渲染
//                  "bStateSave" : false, //在第三页刷新页面,会自动到第一页
//         "retrieve" : true,       //类似单例模式,重复利用以存在对象。
        "iDisplayLength" : 5,
        "iDisplayStart" : 0,

        "select": {
            style:    'os',
            selector: 'td:first-child'
        },
        "ordering": false,//全局禁用排序
        "ajax": {  //ajax方式向后台发送请求
            "type": "POST",
            "url":"mvc/onDuty/find-user-duty",
            "data":{dutyUserId:uid},//传递的数据
            "dataType" : "json"
        },
        "columns" : [//对接收到的json格式数据进行处理,data为json中对应的key
            {"data":"id"},
            {"data" : "actualDutyUser.realName"} ,
            {"data" : "onDutyDate"},
            {"data": "categoryKey.typeName.keyValue"},

        ],
        //渲染
         "columnDefs": [
             {
                 "render": function ( data, type, row ) {
                     return "<input type='radio' name='onDutyToId'  value='" + data + "'>";
                 },
                 "targets": 0 //指定渲染列:第一列(渲染第一列为单选框,data自动匹配为  {"data":"id"}中数据)
             },
         ],
        "oLanguage" : { // 国际化配置
            "sProcessing" : "正在获取数据,请稍后...",
            "sLengthMenu" : "显示 _MENU_ 条",
            "sZeroRecords" : "没有找到数据",
            "sInfo" : "从 _START_ 到  _END_ 条记录 总记录数为 _TOTAL_ 条",
            "sInfoEmpty" : "记录数为0",
            "sInfoFiltered" : "(全部记录数 _MAX_ 条)",
            "sInfoPostFix" : "",
            "sSearch" : "查询",
            "sUrl" : "",
            "oPaginate" : {
                "sFirst" : "第一页",
                "sPrevious" : "上一页",
                "sNext" : "下一页",
                "sLast" : "最后一页"
            }
        },
//                  initComplete:initComplete,
    });
                // dutyTable.fnDraw();//重绘
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
后台控制层:

 
 
  • 1
  • 2
 /**
     * @(dataTable格式)
     * @param:[onDuty, sEcho, start:开始索引数, length:每页显示数量]
     * @return:java.util.Map<java.lang.String,java.lang.Object>
      */
    @RequestMapping(value="find-user-duty",method=RequestMethod.POST)
    @ResponseBody
    public Map<String,Object> getClassesTeacher(AlertOnDuty onDuty,@RequestParam(value = "sEcho",required = false)Integer sEcho, @RequestParam("start")Integer start,@RequestParam("length")Integer length) {

        this.map = new HashMap<String, Object>();

        //获取分页控件的信息
        this.pageBean = this.getBaseAllService().getOnDutyService().getManOnDutyList(onDuty,start,length);

        map.put("aaData", pageBean.getResult());
        //页数信息配置
        map.put("sEcho", sEcho);
        map.put("iTotalRecords", pageBean.getTotalRow());
        map.put("iTotalDisplayRecords",pageBean.getTotalRow());
        return map;
    }
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

其中:start:开始索引数, length:每页显示数量。sEcho记不清了,可有可无。 
start和length都是向后台发送请求时自带的参数。 
aaData为dataTable接收数据的变量名称,是dataTable默认的。

这里写图片描述

这里写图片描述

效果: 
这里写图片描述

这里写图片描述
本文只是从实际项目入手讲解,不够系统全面,如想更好使用DataTables建议参考官方文档。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值