一款用于表格数据自定义排序的jQuery插件jquery.tablesortable.js(附ajax例子)
2016-12-13 11:26
886 查看
由于项目上需要,自己花时间写了一款用于表格数据自定义排序的jQuery插件jquery.tablesortable.js,
仿EasyUI,数据列启用自定义排序后,该列标题后将出现向上或者向下的三角形,点击列标题设置新的排序参数。使用方法都直接写在js里了,没什么技术难度,就直接上代码吧。
附例子:
点这里去下载
附的例子是asp.net mvc的,但插件是基于jQuery 的,当然可以用于其他语言的。
仿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("data:image/jpg;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAALCAIAAADN+VtyAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAABzSURBVChTY/gPAT9uLY4J6Lv4A8r9/x8sARQNFGUAAnaTTpgcA0IUAmByDBtikUQhACzHcHbLakxw9B7EDmyAod1CHgNoF+78xHBxhhuaJewmrWe/gIz6gSwHEQUZBTYQKgcXBQK45T9uHdx7HSb6//9/AFztmH+QWaTdAAAAAElFTkSuQmCCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=="); background-position: center center; background-repeat: no-repeat; } .sortable-sort-asc { background-image: url("data:image/jpg;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAFCAIAAAD38zoCAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAABFSURBVBhXY/gPAwsv/tjVUfj//wsIFyox4+IPBlE3BgaGDbGiEDmQBFwUAiByDHOv/EcWhQCgHMOaWz9SU+tSUcHhKYUAuK0+12A7dLIAAAAASUVORK5CYIIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=="); } .sortable-sort-desc { background-image: url("data:image/jpg;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAFCAIAAAD38zoCAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAABESURBVBhXYzg8pTAVHdStufWDYUOsKAMaEHWbe+U/w///L1DkRN1mXPzx/z9IAghgcjBRIIBIAMGLXR2FC2Gi////BwD4gD7X7i0baAAAAABJRU5ErkJgggAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=="); }
//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 的,当然可以用于其他语言的。
相关文章推荐
- 自己动手丰衣足食之表格排序插件jquery.tableSort.js
- 新学的插件jquery.tablesorter很好用,说说遇到的表格动态添加的数据不能排序的问题
- jquery.tableSort.js表格排序插件使用方法详解
- 使用jquery的tablesorter插件进行表格排序
- 使用jquery的tablesorter插件进行表格排序
- javascript table排序之jquery.tablesorter.js
- jquery表格分组插件-jquery.tablegroup.js
- jquery tablesorter.js 支持中文表格排序改进
- 一个简单的jQuery插件ajaxfileupload.js实现ajax上传文件例子
- 使用jquery的tablesorter插件进行表格排序
- jQuery入门教程-使用tablesorter插件(表格排序)
- jquery +jquery.tablesorter+jquery.tablednd_0_5实现table表格可按行拖拽,按列排序,并可以保存排序后的结果
- JQuery插件——tablesorter插件(表格排序)
- Jquery 模板插件 jquery.tmpl.js 的使用方法(1):基本语法,绑定,each循环,ajax获取json数据
- JS实现table表格数据排序(可支持动态数据+分页效果)
- jQuery 表格排序插件 Tablesorter 使用
- jQuery+Ajax实现表格数据不同列标题排序(为表格注入活力)
- jQuery html表格排序插件:tablesorter
- 基于jquery的Table表格排序插件
- jQuery 表格排序插件 Tablesorter 使用