dataTables的使用

一、datatable的初始化

项目预览

引入资源文件

1.原滋原味的datatable样式

            <link rel="stylesheet" href="/static/plugins/datatables/dataTables.css">
            <script src="jquery.js"><script>
            <script src="plugins/datatables/dataTables.js"><script>
            <script>
                $("#example").dataTable({
                    
                })
            </script>

2.基于bootstrap样式引入静态资源

            <link rel="stylesheet" href="less/bootstrap.css">
            <link rel="stylesheet" href="../plugins/datatables/dataTables.bootstrap.css">
            <script src="jquery.js"><script>
            <script src="bootstrap.js"><script>
            <script src="plugins/datatables/dataTables.js"><script>
            <script src="../plugins/datatables/dataTables.bootstrap.js"></script>
            <script>
                $("#example").dataTable({
                    
                })
            </script>

ps:datatables.bootstrap.js是为了给table中的dom元素加上bootstrap样式类名使页面在渲染的时候能够按照bootstrap的样式进行渲染,这里也必须引入datatable.js

3.基于jqueryUI的资源引入与bootstrap的差不多

二、datatable的数据

1.数据写在页面中

    **html**

         <table id="dataTable" class="display text-center cell-border table-bordered " cellspacing="0" style="width:100%;line-height:60px;" >
                <thead>
                    <tr>
                        <th class="tableTrborder">用户ID</th>
                        <th class="tableTrborder">用户名</th>
                        <th class="tableTrborder">创建时间</th>
                        <th class="tableTrborder">更新时间</th>
                        <th class="tableTrborder">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>用户ID1</td>
                        <td>用户名$</td>
                        <td>2016-12-26</td>
                        <td>2017-1-6</td>
                        <td>
                            <button class="btn btn-primary btn-small" >编辑</button>
                            <button class="btn btn-danger btn-small" >删除</button>
                        </td>
                    </tr>
                </tbody>
          </table>
          
    **js部分**

          <script>
                //初始化页面配置
                var lang = {
                                "sProcessing": "数据加载中...",
                                "sLengthMenu": "每页 _MENU_ 项",
                                "sZeroRecords": "没有匹配结果",
                                "sInfo": "当前显示第 _START_ 至 _END_ 项,共 _TOTAL_ 项。",
                                "sInfoEmpty": "当前显示第 0 至 0 项,共 0 项",
                                "sInfoFiltered": "(由 _MAX_ 项结果过滤)",
                                "sInfoPostFix": "",
                                "sSearch": "搜索:",
                                "sUrl": "",
                                "sEmptyTable": "表中数据为空,可以尝试修改上面各选项再次查找",
                                "sLoadingRecords": "数据加载中...",
                                "sInfoThousands": ",",
                                "oPaginate": {
                                    "sFirst": "首页",
                                    "sPrevious": "上页",
                                    "sNext": "下页",
                                    "sLast": "末页",
                                    "sJump": "跳转"
                                },
                                "oAria": {
                                    "sSortAscending": ": 以升序排列此列",
                                    "sSortDescending": ": 以降序排列此列"
                                }
                            };
                $("#example").dataTable({
                    "language":lang,
                    "destroy":true, //这个如果不加的话不能够再次调用这个函数
                    //文字中文化
                })
          </script>

2.Ajax直接请求数据 ps:直接请求的要符合datatable的数据格式要求,无论是object格式的还是arry数组格式的

    **html** 

                <table id="dataTable" class="display text-center cell-border table-bordered " cellspacing="0" style="width:100%;line-height:60px;" >
                    <thead>
                        <tr>
                            <th>用户名称</th>
                            <th>用户ID</th>
                            <th>创建日期</th>
                            <th>更新日期</th>
                        </tr>
                    </thead>
                </table>
                
    **js部分** 

            $("#dataTable").dataTable({
                "language": lang,
                "ajax": '/ajax',
                "columns": [
                    { "data": "useName" },
                    { "data": "userId" },
                    { "data": "createTime" },
                    { "data": "updateTime" }
                ]
            });
            
    **返回的数据格式**(object)因为使用规定的数据格式,后台修改参数的原因可以使用**自定义Ajax加载数据格式**               


         {"data":[
                {
                    "useName":"hult",
                    "userId":"gmbub2",
                    "createTime":"2012-10-06",
                    "updateTime":"1976-05-30"
                },
                {
                    "useName":"qtik",
                    "userId":"nsgta6",
                    "createTime":"1980-12-14",
                    "updateTime":"2004-07-24"
                },
                {
                    "useName":"grqw",
                    "userId":"bpkci8",
                    "createTime":"1980-06-06",
                    "updateTime":"1984-03-17"
                }
                ]}

3.自定义Ajax直接请求数据 ps:就是使用回调函数处理数据然后再返回

    **html**      ps:直接可以去掉<thead>标签直接在页面中写

                <table id="dataTable" class="display text-center cell-border table-bordered " cellspacing="0" style="width:100%;line-height:60px;" >
                  
                </table>
                
    **js部分** 

            $("#dataTable").dataTable({
                "language": lang,
                "destroy":true, //这个如果不加的话不能够再次调用这个函数
                "ajax":function (data,callback,setting) {
                    $.ajax({
                        url:"/defined",
                        success:function (returnData) {
                            //这边只是为了修改数据的格式使其符合datatable的数据格式
                            console.log(data);
                            var result={};
                            result.data=returnData.tian;
                            callback(result)
                        }
                    })
                },
                "columns": [
                    {
                        "data": "useName",
                        "title":"用户名称"
                    },
                    {
                        "data": "userId",
                        "title":"用户ID"
                    },
                    {
                        "data": "createTime",
                        "title":"创建日期"
                    },
                    {
                        "data": "updateTime",
                        "title":"更新日期"
                    }
                ]
            });
            
    **返回数据** 

            {
                "tian":[
                    {
                        "useName":"mhrs",
                        "userId":"eqrho10",
                        "createTime":"2007-01-21",
                        "updateTime":"2011-03-29"
                    },
                    {
                        "useName":"llmf",
                        "userId":"ynycd3",
                        "createTime":"1985-01-10",
                        "updateTime":"2003-11-14"
                    },
                    {
                        "useName":"nfmw",
                        "userId":"hrctz4",
                        "createTime":"2013-01-19",
                        "updateTime":"1976-07-13"
                    }
                ]
            }

4.自定义Ajax直接请求数据开启服务器模式 ps:就是后台数据量非常大的时候这时候就要启用这个模式,因为数据量太大耗费浏览器的资源太多,所以才有服务器模式,就是每次只请求一个分页的数据,这是就要将一个页面的展示多少条,排序的参数,搜索的关键字都要通过回调函数的function(data,callback,setting){}中的data参数获取,处理然后再传给ajax的参数中

    **html**      ps:直接可以去掉<thead>标签直接在页面中写

                <table id="dataTable" class="display text-center cell-border table-bordered " cellspacing="0" style="width:100%;line-height:60px;" >
                  
                </table>
                
    **js部分** 

             function getParamter(event) {
                var query={};
                query={
                    "keyWord":      event.search.value, //搜索的关键字
                    "order":        event.order,        //排序
                    "currentPage":  event.length        //当前页多少数据
                };
                return query
             }
    
            $("#dataTable").dataTable({
                "language": lang,
                "destroy":true, //这个如果不加的话不能够再次调用这个函数
                "serverSide": true,
                //主要的区别


                 ajax:function (data,callback,setting) {
                    console.log(data,'t');//服务器开启的时候会有一个对象,若果不是服务器模式不会有数据
                    console.log(callback,'z');//回调函数
                    console.log(setting,'h');
                    $.ajax({
                        url:"/defined",
                        data:JSON.stringify(getParamter(data)),
                        success:function (data) {
                            //这边只是为了修改数据的格式使其符合datatable的数据格式
                            console.log(data);
                            var result={};
                            result.data=data.tian;
                            result.recordsFiltered =100;
                            result.recordsTotal = 10;
                            callback(result)
                        }
                    })
                },
                "columns": [
                    {
                        "data": "useName",
                        "title":"用户名称"
                    },
                    {
                        "data": "userId",
                        "title":"用户ID"
                    },
                    {
                        "data": "createTime",
                        "title":"创建日期"
                    },
                    {
                        "data": "updateTime",
                        "title":"更新日期"
                    }
                ]
            });
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,046评论 25 707
  • WebSocket-Swift Starscream的使用 WebSocket 是 HTML5 一种新的协议。它实...
    香橙柚子阅读 23,842评论 8 183
  • 这本小说看看停停的,花了5天看完了,通篇看下来,实话说不知道在讲什么?不知道为什么会成为现象级的小说?脑海中一团浆...
    果彭阅读 228评论 0 1
  • 写作背景@加班到十点半,看到经常在这卖菜的二老还在外头,就不免送上一杯热水闲聊起来,在这个碰巧是福州入冬雨夜里,竟...
    墨不尽阅读 211评论 0 3