js实现对table数据列排序

借助于强大的jquery库,通过一些简单的js代码来实现对table数据列进行排序。排序是通过调整table的tr的顺序重新显示,全部在客户端上完成,不需要和服务器交互,因此减轻了服务器的压力。

实现排序的js代码如下:

//点击表格的列进行排序

function tableSort(jqTableObj) {
    jqTableObj.find('tr th').click(
        function(){
            var dataType = $(this).attr('dataType') || 'text';
            var index = jqTableObj.find('thead th').index(this) + 1;
            var arr = [];
            var row = jqTableObj.find('tbody tr');


            $.each(row, function(i){arr[i] = row[i]});


            if($(this).hasClass('current')){
                arr.reverse();
            } else {
                arr.sort(Utils.sortStr(index, dataType))


                jqTableObj.find('thead th').removeClass('current');
                $(this).addClass('current');
            }


            var fragment = document.createDocumentFragment();


            $.each(arr, function(i){
                fragment.appendChild(arr[i]);
            });


            jqTableObj.find('tbody').append(fragment);
        }
    );    


    var Utils = (function() {
        function sortStr(index, dataType){
            return function(a, b){
                var aText=$(a).find('td:nth-child(' + index + ')').attr('_order') || $(a).find('td:nth-child(' + index + ')').text();
                var bText=$(b).find('td:nth-child(' + index + ')').attr('_order') || $(b).find('td:nth-child(' + index + ')').text();


                if(dataType != 'text'){
                    aText=parseNonText(aText, dataType);
                    bText=parseNonText(bText, dataType);


                    return aText > bText ? -1 : bText > aText ? 1 : 0;
                } else {
                    return aText.localeCompare(bText)
                }
            }


        }

要想让上面的代码工作,需要在原有的table中注意几点。

1、表头的tr其父元素为thead,另外表头列使用th,同时要使用dataType属性名来标示数据的类型,类型可以为text(默认),int和float;

2、显示table数据的tr父元素为tbody,显示数据的列用td,可以使用_order属性指定该字段的真实值。

table 示例如下:

 function parseNonText(data, dataType){
            switch(dataType){
                case 'int':
                    return parseInt(data) || 0
                case 'float':
                    return parseFloat(data) || 0
                default :
                return filterStr(data)
            }
        }

案例网站


      

你好!对于你的问题,可以使用 Java8 的 Stream API 和 Collectors.groupingBy() 方法来实现按照某个字段进行分组,value 是以逗号分割对象的某个属性拼接的功能。以下是示例代码: 假设有一个名为 Person 的实体类,其中包含了 name 和 age 两个字段: ``` public class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } } ``` 现在有一个包含多个 Person 对象的 List,我们要按照 age 字段进行分组,并将每个分组中的 Person 对象的 name 属性拼接成一个字符串: ``` List<Person> personList = Arrays.asList( new Person("Alice", 20), new Person("Bob", 25), new Person("Charlie", 20), new Person("David", 30), new Person("Eva", 25) ); Map<Integer, String> groupedMap = personList.stream() .collect(Collectors.groupingBy(Person::getAge, Collectors.mapping(Person::getName, Collectors.joining(",")))); ``` 上述代码中,我们使用 stream() 方法将 List 转化为 Stream,然后调用 Collectors.groupingBy() 方法,以 Person::getAge 作为分类器进行分组,最终得到一个 Map<Integer, String> 对象,其中 key 为 age,value 为该 age 对应的 Person 对象的 name 属性拼接而成的字符串。 在 Collectors.groupingBy() 方法中,我们使用 Collectors.mapping() 方法来将 Person 对象转化为其 name 属性,并使用 Collectors.joining() 方法来将多个 name 属性拼接为一个字符串,其中使用逗号作为分隔符。 希望这个示例能够帮到你!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值