一款用于表格数据自定义排序的jQuery插件jquery.tablesortable.js(附ajax例子)

由于项目上需要,自己花时间写了一款用于表格数据自定义排序的jQuery插件jquery.tablesortable.js,
仿EasyUI,数据列启用自定义排序后,该列标题后将出现向上或者向下的三角形,点击列标题设置新的排序参数。使用方法都直接写在js里了,没什么技术难度,就直接上代码吧。
这里写图片描述
这里写图片描述

//css文件
/********************************************************************************
 * Copyright (C) Corporation. All rights reserved.
 * 
 * Author      :  lihaitao 
 * Email        : lhtzbj12@126.com
 * Create Date  :  2016-11-15
 * Description  : 表格自定义排序插件的样式
 * 
 *          
 * Revision History:
 *      Date         Author               Description
 *      2016-11-15   lihaitao               create
 *  

*********************************************************************************/

.sortable-sort-default, .sortable-sort-asc, .sortable-sort-desc {
    display: inline-block;
    width: 8px !important;
    height: 11px !important;
    background-image: url("");
    background-position: center center;
    background-repeat: no-repeat;
}

.sortable-sort-asc {
    background-image: url("");
}

.sortable-sort-desc {
    background-image: url("");
}
//js文件
/********************************************************************************
 * Copyright (C) Corporation. All rights reserved.
 * 
 * Author      :  lihaitao 
 * Email        : lhtzbj12@126.com
 * Create Date  :  2016-11-15
 * Description  : 表格自定义排序插件
 * 
 *          
 * Revision History:
 *      Date         Author               Description
 *      2016-11-15   lihaitao               create
 *  

*********************************************************************************/
//自定义排序插件,传入当前表格加载数据的排序规则orderby、direction,以及回调函数
//callback为点击th后激发的回调函数,给回调传两个值,新的orderby和direction
//有两种方法让th启用自定义排序
//一、在DOM中,给th添加属性data-field(数据库中表字段)和data-sortable="true"
//二、调用插件的初始化语句中给参数columns附值
//两种方法可以同时使用,如果对同一th使用了两种方法,则以columns有效
//要求表格基本结构
/*
<table id="dataGrid">
    <thead>
        <tr>
           <th data-field="Id" data-sortable="true">ID</th>                        //第一种方法让th启用自定义排序  data-field为对应数据库中表字段         
           <th>开始时间</th>
           <th>结束时间</th>
           <th>创建时间</th> 
        </tr>                
    </thead>
    <tbody> 
    //tr
    </tbody>
</table>
//调用实例
 $("#dataGrid").Sortable({
    orderby:'CreateTime', //当前数据已按CreateTime排序                              direction:'desc',     //当前数据已按降序排序
    columns:[{ index: 1, field: 'StartTime' }, { index: 3, field: 'CreateTime' }],  //第二种方法让th启用自定义排序:表格中可用于排序的列index第th的索引,field为对应数据库中表字段
    callback:function(orderby,direction){                                           //回调函数,当点击th时回调
        //do something
        //orderBy,direction为点击后要向服务器请求的新参数
    }           
 });
*/
(function ($) {
    $.fn.Sortable = function (options) {
        var table = this;
        var orderby = options.orderby;
        var direction = options.direction;
        var callback = options.callback;
        var columns = options.columns;
        if (columns == undefined)
            columns = [];
        //找出表中th有属性 data-field 和 data-sortable=‘true’的th,填充columns
        $(this).find("th").each(function (i, e) {
            if ($(e).attr("data-field") != null &&
                $(e).attr("data-field").length > 0 &&
                $(e).attr("data-sortable") != null &&
                $(e).attr("data-sortable") == "true") {
                var entity = { index: i, field: $(e).attr("data-field") };
                //判断当前th是否在columns已存在,不存在则加入
                if ($(columns).filter(function (ci, ce) { return ce.index == i; }).length == 0) {
                    columns.push(entity);
                }
            }
        })
        $(columns).each(function (i, c) {
            var th = $(table).find("th:eq(" + c.index + ")");
            if (th.length == 0) return true;
            e = th[0];
            $(e).attr("data-field", c.field);
            //设置鼠标样式
            $(e).css("cursor", "pointer");
            //添加i
            var sonI = $(e).children("i");
            if (sonI.length == 0) $(e).append("<i></i>");
            sonI = $(e).children("i").removeClass();
            //判断是否当前已经排序字段
            var nextdirection = 'asc';
            if (c.field == orderby) {
                if (direction == "asc") {
                    sonI.addClass("sortable-sort-asc");
                    nextdirection = "desc";
                } else {
                    sonI.addClass("sortable-sort-desc");
                    nextdirection = "asc";
                }
            }
            else {
                sonI.addClass("sortable-sort-default")
            }
            //添加点击事件,必须先off,否则会重复触发
            $(e).off('click');
            $(e).on('click', function () {
                if (callback) {
                    callback(c.field, nextdirection);
                }
            });

        });
        return this;
    };
})(jQuery);

附例子:

点这里去下载
附的例子是asp.net mvc的,但插件是基于jQuery 的,当然可以用于其他语言的。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值