首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Vaadin-Grid的数字列不按数字排序

基础概念

Vaadin-Grid 是 Vaadin 框架中的一个组件,用于在 Web 应用程序中显示和编辑表格数据。它支持多种列类型,包括数字列。数字列通常用于显示和排序数值数据。

相关优势

  1. 灵活性:Vaadin-Grid 提供了丰富的配置选项,可以轻松定制列的显示和行为。
  2. 性能:对于大量数据,Vaadin-Grid 提供了虚拟滚动和分页功能,确保应用程序的性能。
  3. 集成性:可以轻松与其他 Vaadin 组件和后端服务集成。

类型

Vaadin-Grid 的列类型包括:

  • 文本列
  • 数字列
  • 日期列
  • 布尔列
  • 自定义列

应用场景

Vaadin-Grid 适用于需要显示和编辑表格数据的 Web 应用程序,特别是在需要处理大量数据和复杂数据结构的情况下。

问题描述

Vaadin-Grid 的数字列不按数字排序,可能是由于以下原因:

  1. 数据类型不匹配:列中的数据类型可能不是数字类型,导致排序时出现问题。
  2. 自定义排序逻辑:可能存在自定义的排序逻辑,但没有正确实现。
  3. 浏览器兼容性:某些浏览器可能对数字排序的处理方式不同。

解决方法

1. 确保数据类型匹配

确保数字列中的数据确实是数字类型。可以通过以下方式检查和转换数据类型:

代码语言:txt
复制
grid.setColumns("name", "age");

grid.getColumnByKey("age").setComparator((a, b) -> {
    if (a == null || b == null) {
        return 0;
    }
    return Integer.compare((Integer) a, (Integer) b);
});

2. 自定义排序逻辑

如果需要自定义排序逻辑,确保正确实现比较器:

代码语言:txt
复制
grid.getColumnByKey("age").setComparator((a, b) -> {
    if (a == null || b == null) {
        return 0;
    }
    return Integer.compare((Integer) a, (Integer) b);
});

3. 浏览器兼容性

确保在不同浏览器中测试排序功能,以确保兼容性。如果问题仅在特定浏览器中出现,可能需要针对该浏览器进行特殊处理。

示例代码

以下是一个完整的示例,展示了如何配置 Vaadin-Grid 的数字列并实现正确的排序:

代码语言:txt
复制
import com.vaadin.flow.component.grid.Grid;
import com.vaadin.flow.component.orderedlayout.VerticalLayout;
import com.vaadin.flow.router.Route;

import java.util.ArrayList;
import java.util.List;

@Route("")
public class MainView extends VerticalLayout {

    public MainView() {
        Grid<Person> grid = new Grid<>(Person.class);
        grid.setColumns("name", "age");

        List<Person> persons = new ArrayList<>();
        persons.add(new Person("Alice", 30));
        persons.add(new Person("Bob", 25));
        persons.add(new Person("Charlie", 35));

        grid.setItems(persons);

        grid.getColumnByKey("age").setComparator((a, b) -> {
            if (a == null || b == null) {
                return 0;
            }
            return Integer.compare((Integer) a.getAge(), (Integer) b.getAge());
        });

        add(grid);
    }

    public static class Person {
        private String name;
        private Integer age;

        public Person(String name, Integer age) {
            this.name = name;
            this.age = age;
        }

        public String getName() {
            return name;
        }

        public Integer getAge() {
            return age;
        }
    }
}

参考链接

通过以上方法,您应该能够解决 Vaadin-Grid 数字列不按数字排序的问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

获取不连续数字中缺的数字

且将断号的号码找出来。 需求分析 凭证的短号规则,也就是这个凭证是通过怎么一个规则来判断短号的。最后和产品了解每个公司都有自己的规则。不一定是纯数字,也有可能标记有横杠特殊字符等。...砍需求,由于我们在年底进行开发的版本是POC版本,并且时间非常的紧急(以至于我们每天都要搞到11点)。所以说不用很复杂的业务需求,所以最后讨论下来先做为写死的纯数字校验。 所以有了今天这篇文章。...CODOING 其实有很多同学看到这个一串数字断号校验,这有什么可讲的呢?简单的一批。 刚开始的思路:这些数字有可能从零开始,也有可能从一开始,也有可能从。也有可能中间有很多断号的等等。。。。...{ //边界判断 if (nos.size() <= 1) { return null; } //先进行一次排序...min = (long) objects[0]; min <= max; min++) { integers.add(min); } //返回缺失的数字

2.1K30
  • Excel公式练习38: 求一列中的数字剔除掉另一列中的数字后剩下的数字

    本次的练习是:如下图1所示,在单元格区域A2:A12和B2:B12中给定两列数字,要在列C中从单元格C2开始生成一列数字。规则如下: 1. 列B中的数字的数量要小于等于列A中数字的数量。 2....列B中的任意数字都可以在列A中找到。 3. 在列A或列B已存放数字的单元格之间不能有任何空单元格。 4. 在列C中的数字是从列A中的数字移除列B中的数字在列A中第一次出现的数字后剩下的数字。 5....换句话说,列B和列C中的数字合起来就是列A中的数字。 ? 图1 在单元格D1中的数字等于列A中的数字数量减去列B中的数字数量后的值,也就是列C中数字的数量。...公式的思路就是构造一个数组,能够实现在List1和List2之间执行MATCH函数查找时,列C中的数值就是找不到的值,返回FALSE。 然而,实现起来并不是想像中的那么简单。...中要返回的数字数量: =COUNT(List1)-COUNT(List2) 1.

    3.4K20

    java中的sort排序算法_vba中sort按某列排序

    大家好,又见面了,我是你们的朋友全栈君。 C++中提供了sort函数,可以让程序员轻松地调用排序算法,JAVA中也有相应的函数。...1.基本元素排序:Array.sort(排序数组名) package test; import java.util.*; public class main { public static void...可以使用Interger.intvalue()获得其中int的值 下面a是int型数组,b是Interger型的数组,a拷贝到b中,方便从大到小排序。capare中返回值是1表示需要交换。...和2差不多,都是重载比较器,以下程序实现了点的排序,其中x小的拍前面,x一样时y小的排前面 package test; import java.util.*; class point { int...如果只希望对数组中的一个区间进行排序,那么就用到sort中的第二个和第三个参数sort(a,p1,p2,cmp),表示对a数组的[p1,p2)(注意左闭右开)部分按cmp规则进行排序 发布者:全栈程序员栈长

    2.2K30

    力扣题目汇总(机器人返回原点,按奇偶排序,数字的补数)

    此外,假设每次移动机器人的移动幅度相同。 示例 1: 输入: "UD" 输出: true 解释:机器人向上移动一次,然后向下移动一次。所有动作都具有相同的幅度,因此它最终回到它开始的原点。...它最终位于原点的左侧,距原点有两次 “移动” 的距离。我们返回 false,因为它在移动结束时没有返回原点。...moves.count('L') == moves.count('R'): return True else: return False 按奇偶排序数组...if A[j] % 2 == 0: A[i], A[j] = A[j], A[i] i += 1 return A 数字的补数...补数是对该数的二进制表示取反。 注意: 给定的整数保证在32位带符号整数的范围内。 你可以假定二进制数不包含前导零位。

    66830

    史上最速解决:Power BI由按列排序导致的循环依赖

    引子 当我们在处理这样的数据时,想要进行排列时,会发现它并没有按照我们预想的按照1……9,10,11,12……这样的排序: 因为文本和数字在一起的列,数字只是文本。...如果我们想要按照预想的顺序排列,能做的应该也只有按列排序,因此我们将周数中的数字提取出来作为单独一列: 周数2 = MID([周数],6,10) 再选中[周数]列,点击“按列排序”,选择[周数2],...原因分析 因为[周数2]这一列是由[周数]生成的,因此对[周数]进行排序计算时,引擎需要计算按列排序的目标[周数2]这一列的大小以便排序,而在计算[周数2]的时候发现,它是由[周数]计算而来,这就产生了循环依赖...解决问题 我们仍然对这个表添加一列[周数2]: 刚才我们说过,[周数]对[周数2]按列排序是会导致循环依赖的。但是如果我再根据[周数]添加一列新列,它和[周数2]是否还存在循环依赖关系呢?...结论 当遇到因为按列排序而导致的循环依赖问题,可以再新建复制一列想要排序的列,这样两个都是由原列计算而来的列直接并没有直接关系,也就不存在循环依赖,因此可以放心地进行按列排序。

    4.4K10

    按【从非数字到数字的转换】分列,有小数点怎么办?

    前面的文章《这样的数据分列也一键搞定!真是太Power了!》...里,提到了Power BI的分裂功能里有新的“按从非数字到数字的转换”分列功能,可以轻松实现如下分列: 但是,马上带来一个问题:如果数字中间是有小数点的,怎么办?...比如这个: 用原来的分列,所得的结果通常是BYD(不要的): 不过,这个问题解决起来其实非常简单,我们看一下生成的代码: 其中的数字列表是不是好明显?...其中的{"0".."9"}就是分列的标志位啊。 咱们给它加个小数点进去,同时把原来多出的列名删掉: 马上搞定!...Power Query就是这样,学会看懂操作生成步骤的公式代码,抓住其中的关键参数,改一改,就能实现很多看似很难的需求——最核心的其实还是把基础打好,然后多看多练,一通百通。

    1.3K20

    2.37 PowerBI数据建模-按列排序的副作用,ALL失效了

    使用ALL函数来计算占比,明明公式正确,返回的百分比却都是100%,百思不得其解,这是软件的Bug吗? 举例基于下表,计算每个班级的人数占比。...班级人数'[人数])总人数_Wrong = CALCULATE([人数],ALL('班级人数'[班级]))班级人数占比_Wrong = DIVIDE([人数],[总人数])异常结果如下:解决方案班级这一列使用了按列排序...,把班级字段拖入报表中的时候,实际上还拖入了一个看不到的班级排序字段,这样才能实现排序的效果。...这种情况下,ALL函数只用了一个字段,并没有彻底清除筛选,所以分母的总人数返回的还是每个班级的人数。把字段和排序字段都放到ALL的参数中,就会返回正确的结果。...本例把ALL的参数调整为班级和用于排序的班级排序字段,如下:总人数 = CALCULATE([人数],ALL('班级人数'[班级],'班级人数'[班级排序]))拓展按列排序还会有其他的副作用,比如判断某个被排序的字段是否被筛选

    3500

    【排序5】基数排序:数字的组织与整理艺术

    基数排序 1、基本思想 基数排序(Radix Sort)是一种非比较排序算法,它根据数字的每一位来对元素进行排序。它适用于排序整数或固定长度的字符串。...基数排序的主要思想是从最低位(个位)开始,依次对所有元素进行排序,然后再从次低位(十位)开始,以此类推,直到最高位(或最长的字符串长度)排序完成。 2、基本步骤 1、获取待排序的整数列表。...2、初始化一个临时数组,用于存储每个位数的数字出现的次数。 3、从最低位开始,依次遍历待排序的整数列表中的每个数字,统计每个位数的数字出现的次数。 4、将统计结果存储到临时数组中。...5、根据临时数组中的统计结果,依次将待排序的整数列表中的数字移动到正确的位置。 6、重复步骤3-5,直到最高位遍历完毕。...今天的分享就到这里了,后面还会分享更多算法,敬请关注喔!!!✌️

    14310

    用数字(而不是字母)表示Excel的列的方法

    本文介绍在Excel表格文件中,用数字而非字母来表示列号的方法。   ...在日常生活、工作中,我们不免经常使用各种、各类Excel表格文件;而在Excel表格文件中,微软Office是默认用数字表示行数,用字母表示列数的,如下图所示:   而这样就带来一个问题:当一个Excel...表格文件的列数相对较多时(比如有几十列,甚至上百列时),用字母表示列数较之用数字表示列数,就相对较为不直观、不清晰,无法很好地判断该文件列的具体数量,如下图所示:   这无疑会给我们的表格数据处理工作带来一些麻烦...对此,我们可以将Excel文件中的行与列均用数字来表示,从而获得更直观的列数,进而方便我们的日常学习与办公。具体设置方法如下。   首先,点击选择左上角的“文件”。   ...此时回到我们的表格文件,可以看到,Excel文件的行与列均用数字来表示了,即可以清晰看到具体的行数与列数,非常直观、清晰。   以上,便完成了我们的设置。

    7000

    Excel里的PP可以按列排序,但你知道它的缺陷吗?

    在我的文章、书或视频中,均介绍过Excel Power Pivot中的按列排序问题,通过按列排序,可以实现一列数据参照另一列的顺序进行排序,具体可以参考文章《PP-入门前奏:传统透视表无法完成的简单的排序问题...但是,这之前一直没有讲,这个功能其实是有个缺陷的:你只能按既定的升序进行排序,不能在生成透视表的时候选择降序。...如下图所示的排序: 当选择降序时,透视表里会转换回Excel中“姓名”的排序方式,而不是Power Pivot中设置的参照排序: 如果需要调整回参照排序,排序选项中要选择...——这需要去调整参照排序列的具体内容,比如原本的参照是1,2,3,4……的,调整为-1,-2,-3,-4…… 总的来说,参照排序目前在Excel里实现的是一种相对固定的方式,但也是对Excel...原只能按照字段本身进行排序的一种很好的补充吧——同时,这个问题在Power BI里并不存在。

    1.3K20

    疫情按下中国数字化转型的“快进键”

    丰富的数字化应用快速进入了各行各业,让几乎所有行业和企业不约而同地意识到了数字化的现实意义,并开始思考如何加速自身企业数字化业务的转型。...疫情引发反思 数字化转型按下“快进键” 一直以来,“数字化转型”都是商业圈的热词,尽管大多数中国企业都在关注数字化转型,但转型的紧迫感和举措执行力并不强。...更重要的是,通过这次数字化办公的大型实践,传统企业深刻感受到,数字化办公不仅是全流程在线化,而是一种数字化的协作方式。 当组织的数字化程度越高,面对突发挑战时受到的冲击就越小,复工复产的活力就越强。...通过这场疫情下的大型数字化革命,“数字化”变成了商业竞争的基础逻辑,从而为中国商业社会的数字化进程按下了“快进键”。...但遗憾的是,大多数的传统企业上云的步调并不快,全面迈向数字化始终缺乏一个契机。 这次疫情的突发,以一种被动的方式,让全社会经历了一场数字化转型升级的实战,也让各个行业重新定义了数字化价值。

    82720

    数字在排序数组中出现的次数

    题目描述 统计一个数字在排序数组中出现的次数 思想:两次二分查找法 有序序列,就使用二分查找的思路。...一开始的思路是先使用二分法找到k,然后从k开始向两边统计k的个数,但统计的这个时间复杂度达到了O(n),导致整个算法的复杂度O(nlogn) 而通过两次二分查找,分别找到第一个k和最后一个k,可以使时间复杂度减少为...O(logn) ps:这里还有个问题是,要在主函数里判断一下,是不是最先函数和最后k函数返回的位置相同,在这个情况下有两种情况.第一个是没找到,第二个是arr里只存在一个数且为k 代码 package...com.algorithm.offer; import org.junit.Test; public class GetNumberOfK { //题目描述 //统计一个数字在排序数组中出现的次数

    45620
    领券