返回顶部
首页 > 资讯 > 前端开发 > VUE >如何解决vue elementUI中table里数字、字母、中文混合排序问题
  • 499
分享到

如何解决vue elementUI中table里数字、字母、中文混合排序问题

2024-04-02 19:04:59 499人浏览 安东尼
摘要

小编给大家分享一下如何解决Vue elementUI中table里数字、字母、中文混合排序问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去

小编给大家分享一下如何解决Vue elementUI中table里数字、字母、中文混合排序问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1.使用场景

使用elementUI中的table时,给包含数字字母中文的名称等字段排序

例如:数字(0->9)->大写字母(A->Z)->小写字母(a->z)->中文拼音(a->z)

2.代码解析

<el-table
   ref="multipleTable"
   border
   tooltip-effect="dark"
   class="xg-table"
   
   max-height="600">
   <el-table-column
    type="selection"
    width="60" />
   <el-table-column
    :default-sort = "{prop: 'DevName'}"
    :sort-method="sortDevName"
    prop="DevName"
    label="名称"
    sortable
    show-overflow-tooltip />
</el-table>

设置属性sortable,会按照自带的机制排序,不符合我们的预期;

所以增加属性 sort-method,在方法中自定义排序方式

<script>
  export default {
    methods: {
      sortDevName(str1, str2) {
       let res = 0
       for (let i = 0; ;i++) {
  if (!str1[i] || !str2[i]) {
   res = str1.length - str2.length
   break
  }
  const char1 = str1[i]
  const char1Type = this.getChartType(char1)
  const char2 = str2[i]
  const char2Type = this.getChartType(char2)
  // 类型相同的逐个比较字符
  if (char1Type[0] === char2Type[0]) {
   if (char1 === char2) {
   continue
   } else {
   if (char1Type[0] === 'zh') {
    res = char1.localeCompare(char2)
   } else if (char1Type[0] === 'en') {
    res = char1.charCodeAt(0) - char2.charCodeAt(0)
   } else {
    res = char1 - char2
   }
   break
   }
  } else {
  // 类型不同的,直接用返回的数字相减
   res = char1Type[1] - char2Type[1]
   break
  }
   }
   return res
  },
  getChartType(char) {
  // 数字可按照排序的要求进行自定义,我这边产品的要求是
  // 数字(0->9)->大写字母(A->Z)->小写字母(a->z)->中文拼音(a->z)
   if (/^[\u4e00-\u9fa5]$/.test(char)) {
  return ['zh', 300]
   }
   if (/^[a-zA-Z]$/.test(char)) {
  return ['en', 200]
   }
   if (/^[0-9]$/.test(char)) {
  return ['number', 100]
   }
   return ['others', 999]
  }
    }
  }
</script>

3.页面效果

 原列表                   ==》》            正序                 ==》》         倒序

如何解决vue elementUI中table里数字、字母、中文混合排序问题如何解决vue elementUI中table里数字、字母、中文混合排序问题如何解决vue elementUI中table里数字、字母、中文混合排序问题

以上是“如何解决vue elementUI中table里数字、字母、中文混合排序问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网VUE频道!

--结束END--

本文标题: 如何解决vue elementUI中table里数字、字母、中文混合排序问题

本文链接: https://lsjlt.com/news/73816.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何解决vue elementUI中table里数字、字母、中文混合排序问题
    小编给大家分享一下如何解决vue elementUI中table里数字、字母、中文混合排序问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去...
    99+
    2024-04-02
  • PHP中如何实现字母数字混合验证码
    这期内容当中小编将会给大家带来有关PHP中如何实现字母数字混合验证码,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。验证码调用地址:Application\Home\Controller\CodeContr...
    99+
    2023-06-04
  • 如何解决elementUI中Table表格问题
    这篇文章主要介绍了如何解决elementUI中Table表格问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.表格样式问题:混乱样式.p...
    99+
    2024-04-02
  • 解决Oracle字符串中包含数字、特殊符号的排序问题
    问题描述:   某小区,需要按照小区、楼栋、单元号、房间号进行排序,但是按照地址描述排序时,因为字符串中包含数字,所以造成了如下的结果, 1号楼之后应该是2号楼,但是查询结果却是10号楼 。   尝试解决...
    99+
    2024-04-02
  • 网页设计中如何解决网页中英文混排行高问题
    这篇文章主要介绍了网页设计中如何解决网页中英文混排行高问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。基本上快被这个问题搞疯了,症状如下症状描述:在ie下(6或7,8没有试...
    99+
    2023-06-08
  • JavaC++解决在排序数组中查找数字出现次数问题
    目录1、题目2、思路3、c++代码4、java代码1、题目 统计一个数字在排序数组中出现的次数。 示例 1: 输入: nums = [5,7,7,8,8,10], target = ...
    99+
    2024-04-02
  • 如何解决Mysql中group by的排序问题
    小编给大家分享一下如何解决Mysql中group by的排序问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 类如 ...
    99+
    2024-04-02
  • 如何解决MyBatis中Enum字段参数解析问题
    小编给大家分享一下如何解决MyBatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati...
    99+
    2023-06-20
  • vue中如何实现input输入校验字母数字组合且长度小于30
    小编给大家分享一下vue中如何实现input输入校验字母数字组合且长度小于30,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体...
    99+
    2024-04-02
  • 如何解决PHP中数组的排序和打乱问题
    这篇文章主要介绍“如何解决PHP中数组的排序和打乱问题”,在日常操作中,相信很多人在如何解决PHP中数组的排序和打乱问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何解决PHP中数组的排序和打乱问题”的疑...
    99+
    2023-06-25
  • 编程开发中如何解决数值排序的问题
    这篇文章主要为大家展示了“编程开发中如何解决数值排序的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“编程开发中如何解决数值排序的问题”这篇文章吧。出题目的: 掌握任意数列之间的排序技巧 解题...
    99+
    2023-06-08
  • 如何理解Java中过滤出字母、数字和中文的正则表达式
    如何理解Java中过滤出字母、数字和中文的正则表达式,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java中过滤出字母、数字和中文的正则表达式(1)过滤出字母的...
    99+
    2023-06-02
  • 如何解决php截取中文字符串乱码问题
    这篇文章主要介绍“如何解决php截取中文字符串乱码问题”,在日常操作中,相信很多人在如何解决php截取中文字符串乱码问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何解决php截取中文字符串乱码问题”的疑...
    99+
    2023-06-20
  • 如何在java中使用分治法中的快速排序解决排序问题
    问题描述:输入一个数字N后,输入N个数字,将N个数字排序后输出。输入:输出:算法设计:快速排序的基本思想是基于分治策略的,其算法思想如下:(1)分解:先从数列中取出一个元素作为基准元素.以基准元素为标准,将问题分解为两个子序列,使小于或等于...
    99+
    2021-12-23
    java基础 java 分治法 快速排序
  • css如何解决完美支持各浏览器连续字母和数字不换行问题
    这篇文章给大家分享的是有关css如何解决完美支持各浏览器连续字母和数字不换行问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 直接给人人代码以下: width: ...
    99+
    2024-04-02
  • 如何解决AngularJs中select绑定数字类型的问题
    这篇文章将为大家详细讲解有关如何解决AngularJs中select绑定数字类型的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、AngularJs中select绑...
    99+
    2024-04-02
  • PHP程序中文字符集处理技巧:解决乱码问题
    标题:PHP程序中文字符集处理技巧:解决乱码问题,需要具体代码示例 随着互联网的快速发展,中文网站的开发变得越来越普遍。在PHP程序中,处理中文字符集是一个常见的问题,特别是在涉及到数...
    99+
    2024-03-07
    php 字符集处理 乱码解决 表单提交
  • MySql中的longtext字段的返回问题如何解决
    这篇文章主要介绍了MySql中的longtext字段的返回问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySql中的longtext字段的返回问题如何解决文章都会有所收获,下面我们一起来看看吧。M...
    99+
    2023-07-02
  • 如何解决css数字文本过长被隐藏的问题
    这篇文章主要介绍了如何解决css数字文本过长被隐藏的问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 css数...
    99+
    2024-04-02
  • 如何解决VBS中字符串连接的性能问题
    这篇文章将为大家详细讲解有关如何解决VBS中字符串连接的性能问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。当然,对于少量的字符串连接,效率并没有对程序造成多大影响,现在让我们考虑一个极端的问题:将1到...
    99+
    2023-06-08
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作