前端排序函数

sortMixArr(arr: any[], field: string, order: string) {
    if (!(arr && arr.length) || !field) {
      return arr
    }
    const nums: any[] = []
    const letters: any[] = []
    const others: any[] = []
    // 日期类型
    const checkDate = (d: any) => isNaN(d) && !isNaN(Date.parse(d))
    arr.forEach(item => {
      const value = item[field]
      if (/^[a-zA-Z]+[\s\S]*$/.test(value)) {
        // 字母校验
        letters.push(item)
      } else if (/^[0-9]+[\s\S]*$/.test(value) && !checkDate(value)) {
        // 数字校验
        nums.push(item)
      } else {
        others.push(item)
      }
    })
    let result: any = []
    result = result.concat(
      nums.sort((a, b) => {
        return a[field] - b[field]
      }),
      letters.sort((a, b) => {
        return a[field].localeCompare(b[field], 'zh')
      }),
      others.sort((a, b) => {
        return a[field].localeCompare(b[field], 'zh')
      })
    )
    return order == 'asc' ? result : result.reverse()
  },

注明:本文仅用于学习记录,如有侵权,请联系删除!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容