DataTable多选全选,抽出公共js

考虑到多个页面都需要用到全选多选,可以将公共的部分抽出到js文件中,引用即可减少代码量。
首先:将公共部分抽出:

var table;
var selectAllFlag = true;
var pageFlag = false;
function deleteAll() {
    $('#deleteAll').click(function() {
        if (selectAllFlag) {
            table.rows().select().data().toArray();
        } else {
            table.rows().deselect();
        }
        selectAllFlag = !selectAllFlag;
    })
};
function deleteSelect() {
    $('#deleteSelect').click(
                    function() {
                        var array = new Array();
                        array = table.rows({selected : true}).data().toArray();
                        if (array.length == 0) {
                            swal({
                                title : "批量删除失败",
                                text : "请先勾选需要删除的数据",
                                type : "error",
                                showConfirmButton : false,
                                timer : 2000
                            });
                        } else {
                            swal(
                                    {
                                        title : "删除账号",
                                        text : "<span style='color:#F44336;'>删除操作后该记录将被删除,并且无法恢复</span>",
                                        type : "info",
                                        showCancelButton : true,
                                        confirmButtonColor : "#2196F3",
                                        confirmButtonText : "确定",
                                        cancelButtonText : "取消",
                                        closeOnConfirm : false,
                                        html : true
                                    }, function() {
                                        for (var i = 0; i < array.length; i++) {
                                            deleteCallback(array[i].id)
                                        }
                                    });
                        }
                    })
}
function buildTableConfigJson(operateCell) {
    var configJson = {
        "searching" : false,
        "lengthChange" : false,
        "pageLength" : 10,
        ordering : false,
        "serverSide" : true,
        select : {
            style : 'multi',
            selector : 'td:first-child'
        },
        language : {
            "lengthMenu" : "_MENU 条记录每页",
            "zeroRecords" : "没有找到记录",
            "info" : "记录数:_TOTAL_",
            "infoEmpty" : "无记录",
            "infoFiltered" : "(从 _MAX_ )条记录过滤",
            "paginate" : {
                "previous" : "上一页",
                "next" : "下一页"
            }
        },
        ajax : {
            dataSrc : 'data',
            complete : function() {
                if (!pageFlag) {
                    table.page('previous').draw('page');
                }
            }
        },
        drawCallback : function(settings) {
            if (table.page() > 0 && table.data().length == 0) {
                pageFlag = false;
            } else {
                pageFlag = true;
            }
        },
        columnDefs: [
            {
                orderable : false,
                className : 'select-checkbox',
                targets : 0,
                render : function(data, type, row) {
                    return '<input class="checkchild" type="checkbox"/>';
                }
            },
            {
                targets : -1,
                render : operateCell,
            }
        ]
    };
    return configJson;
}

取名page.js
放入项目文件中的js中,在需要的html页面用引用js

<script type="text/javascript" src="${request.contextPath}/js/page.js"></script>
<link rel="stylesheet" type="text/css" href="${request.contextPath}/library/datatables/dataTables.select.min.css"/>
<script type="text/javascript" src="${request.contextPath}/library/datatables/dataTables.select.min.js"></script>
page.js

然后在你所需要添加全选框的页面的js中修改代码

var table;
var searchFlag;
var pageFlag = false;
function closeDialog(){
    $('#showUserDialog').modal('hide');
}

function searchRecord() {
    searchFlag = true;
    table.ajax.reload();
}

function reset() {
    searchFlag = false;
    $("#name").val("");
    $("#groupIdSelect").val("");
    table.ajax.reload();
}

function buildSearchParameters(data) {
    var name=$("#name").val();
    var groupId=$("#groupIdSelect").val();
    
    if(name){
        data.name=name;
    }
    if(groupId){
        data.groupId=groupId;
    }
}


function showUserDetail(id){
    $.ajax({
        url : contextPath + "/user/detail/"+id,
        type : "get",
        cache : false,
        dataType : "html",
        success : function(result) {
            $("#modal-content").html(result);
        },
        complete : function(xhr, status){
            forwardToLogin(xhr, status);
        }
    });
    
    $('#showUserDialog').modal({
        show : true,
        backdrop : 'static'
    });
}
function addUser() {
    location.href=contextPath+"/user/add";
}
function updateUser(id) {
    location.href=contextPath+"/user/update/"+id;
}
function deleteOperation(id) {
    swal({
        title : "删除账号",
        text : "<span style='color:#F44336;'>删除操作后该记录将被删除,并且无法恢复</span>",
        type : "info",
        showCancelButton : true,
        confirmButtonColor : "#2196F3",
        confirmButtonText : "确定",
        cancelButtonText : "取消",
        closeOnConfirm : false,
        html : true
    }, function() {
        deleteCallback(id);
    });
}
function deleteCallback(id) {
    $.ajax({
        url : contextPath + "/user/delete/" + id,
        cache : false,
        dataType : "json",
        success : function(result) {
            if (result.code == 1) {
                swal({
                    title : "删除账号",
                    text : "删除账号成功",
                    type : "success",
                    showConfirmButton : false,
                    timer : 1000
                });
                table.draw(false);// 刷新当前页
            }
        }
    });
}
$(function() {
    searchFlag = false;
    var operateCell = function(data, type, row, meta) {
        var html = '<button class="btn btn-sm btn-primary waves-effect" value="'
            + row.id
            + '" onclick="updateUser('
            + row.id
            + ')">编辑</button>&nbsp;&nbsp;&nbsp;'
            + '<button class="btn btn-sm btn-danger waves-effect" value="'
            + row.id
            + '" onclick="deleteOperation('
            + row.id + ')">删除</button>';
    return html;
    }
    var configJson = buildTableConfigJson(operateCell);
    var configAjaxJson = configJson.ajax;
    configAjaxJson.url=contextPath + '/user/list';
    configAjaxJson.data=function(data){
        if (searchFlag) {
            buildSearchParameters(data);
        }   
    };
    configJson.columns = [ 
        {"data" : null},
        {"data" : "name"},
        {"data" : "mobile"},
        {"data" : "position"}, 
        {"data" : null}
    ],
    table = $(".dataTable").DataTable(configJson)
    deleteSelect();
    deleteAll();
});

然后就是html页面

<!DOCTYPE html>
<html>
<head>
<#include "/commonPage.html" />
<script type="text/javascript" src="${request.contextPath}/js/user/main.js"></script>
</head>
<body class="theme-blue">
   <#include "/header.html"/>
   <#include "/menu.html"/>
   <section class="content">
       <div class="container-fluid">
           <!-- 
                   <div class="block-header">
                       <h2>DASHBOARD</h2>
                   </div>
               -->
           <div class="row clearfix">
               <div class="col-lg-12 col-md-12 col-sm-12 col-xs-12">
                   <div class="card">
                       <div class="header">
                           <h2>
                               人员管理<small></small>
                           </h2>
                       </div>
                       <div class="body">
                           <button type="button" class="btn btn-danger waves-effect" id="deleteSelect"><i class="material-icons">delete</i> <span>批量删除</span></button>
                           <button type="button" class="btn btn-primary waves-effect"
                               onclick="addUser()">
                               <i class="material-icons">add</i> <span>添加人员</span>
                           </button>
                           <div class="pull-right" style="vertical-align: middle">
                               <label>姓名: 
                                   <input id="name" type="text" >
                               </label>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
                               <label>部门:
                                   <select id="groupIdSelect">
                                       <option value="">请选择</option>
                                   </select>
                               </label>&nbsp;&nbsp;&nbsp;&nbsp;  
                               <a class="btn btn-info waves-effect" onclick="searchRecord()">搜索</a> 
                               <a class="btn btn-default waves-effect" onclick="reset()">重置</a>
                           </div>
                           
                           <table style="width:100%;"
                               class="table table-bordered table-striped table-hover js-basic-example dataTable">
                               <thead>
                                   <tr>
                                       <th class='th' style="text-align:center;vertical-align:middle">  
                                       <button type="button" class="btn btn-default waves-effect" id="deleteAll"><i class="material-icons">playlist_add_check</i></button>
                                       <th>姓名</th>
                                       <th>手机号码</th>
                                       <th>职位</th>
                                       <!-- <th>部门</th> -->
                                       <th width="20%">操作</th>
                                   </tr>
                               </thead>
                           </table>
                       </div>
                   </div>
               </div>
           </div>
       </div>
   </section>

   <!-- <div class="modal fade" id="showUserDialog" tabindex="-1"
       role="dialog">
       <div class="modal-dialog" role="document"
           style="margin-top: 10%; width: 800px;">
           <div id="modal-content" class="modal-content">
           111
           </div>
       </div>
   </div> -->
</body>
</html>


主要是这一部分


image.png

image.png

以上的效果:


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,079评论 4 62
  • 晚上睡觉前小小苗又在闹着要讲故事,她爸爸已经给她讲了两本绘本了。 劝说之后还跟我大声的喊:我就是要讲故事,一定要讲...
    辉辉2019阅读 502评论 0 0
  • Assets.xcassets是用来存放图像资源文件的。将一个图片放在Assets里面如下图所示: 随着项目的增大...
    翀鹰精灵阅读 7,526评论 -2 4
  • 以前别人总说“因为性格不合而分手,那只不过是借口,只是因为没有了爱分手的万能理由而已。”但自从我招惹上吴某某,我才...
    lst_5b4b阅读 579评论 1 0