首页 > 其他分享 >sort()排序以及多个属性数组对象排序(按条件排序)

sort()排序以及多个属性数组对象排序(按条件排序)

时间:2023-02-09 00:44:55浏览次数:49  
标签:sort arr return age 数组 排序 id

原生排序

let arr = [5,2,1,4,9,8]
for(let i = 0 ; i < arr.length ; i ++) {
             for(let j = 0 ; j < arr.length -1 ; j ++) {
                 if(arr[j] > arr[j+1]){
                     let num = arr[j]
                     arr[j] = arr[j+1]
                     arr[j+1] = num
                     comeout.innerText = arr
                 }
             }
       // 结果 1,2,4,5,8,9

ES6排序

sort() 方法是最强大的数组方法之一。
默认排序顺序为按字母升序。
使用数字排序,你必须通过一个函数作为参数来调用。
比较函数两个参数a和b,a-b 升序,返回b-a 降序
注意: 这种方法会改变原始数组!

// 升序
 arr.sort(function(a,b){
                return a - b
            })
         console.log(arr)
// 结果 1,2,4,5,8,9


// 降序
arr.sort(function(a,b){
                return b - a
            })
          console.log(arr)
// 结果 9,8,5,4,2,1

根据数组中的某个属性排序

let arr_choice = [{id:1},{id:3},{id:2},{id:8},{id:6},{id:4}]
// 升序
arr_choice.sort(function(a,b){
                return b.id - a.id
            })
          console.log(arr_choice)
// 结果:[{"id":1},{"id":2},{"id":3},{"id":4},{"id":6},{"id":8}]
   
         
// 降序
arr_choice.sort(function(a,b){
                return b.id - a.id
            })
         console.log(arr_choice)
// 结果:[{"id":8},{"id":6},{"id":4},{"id":3},{"id":2},{"id":1}]

根据多个属性排序

let arr_multi = [{id:1,age:10},{id:3,age:5},{id:2,age:6},{id:8,age:8},{id:6,age:5},{id:4,age:5}]
// 升序
arr_multi.sort(function(a,b){
                // 默认根据年龄排序,年龄相同则按照id排序
                if(a.age==b.age){
                    return a.id - b.id
                }
                return a.age - b.age
            })
      console.log(arr_multi)
// 结果:[{"id":3,"age":5},{"id":4,"age":5},{"id":6,"age":5},{"id":2,"age":6},{"id":8,"age":8},{"id":1,"age":10}]
         

// 降序
 arr_multi.sort(function(a,b){
                // 默认根据年龄排序,相同则按照id排序
                if(a.age==b.age){
                    return b.id - a.id 
                }
                return b.age - a.age 
            })
            console.log(arr_multi)
// 结果:[{"id":1,"age":10},{"id":8,"age":8},{"id":2,"age":6},{"id":6,"age":5},{"id":4,"age":5},{"id":3,"age":5}]

标签:sort,arr,return,age,数组,排序,id
From: https://www.cnblogs.com/wang-fan-w/p/17103858.html

相关文章

  • 2.K个排序链表归并(Leetcode 23)
    方法一:#include<stdio.h>structListNode{ intval; ListNode*next; ListNode(intx):val(x),next(NULL){}};#include<vector>#include<algorithm>b......
  • 7.两个排序链表的交点(Leetcode 160)
    7.两个排序链表的交点(Leetcode160)方法一:#include<stdio.h>structListNode{ intval; ListNode*next; ListNode(intx):val(x),next(NULL){}};#include......
  • 数组基础知识
    顺序表SeqList.h#define_CRT_SECURE_NO_WARNINGS#ifndef__SEQLIST_H__#define__SEQLIST_H__#include<stdio.h>#include<malloc.h>#include<assert.h>#include<s......
  • 在排序数组中查找元素的第一个和最后一个位置(Leetcode34)
    3.在排序数组中查找元素的第一个和最后一个位置(Leetcode34)给定一个按照升序排列的整数数组nums,和一个目标值target。找出给定目标值在数组中的开始位置和结束位置。如......
  • 1.两个排序链表归并(Leetcode 21)
    1.两个排序链表归并(Leetcode21)#include<stdio.h>structListNode{ intval; ListNode*next; ListNode(intx):val(x),next(NULL){}};classSolution{p......
  • 最长增加子数组
    子串要求一定要挨着12123432145678结果5#include<bits/stdc++.h>usingnamespacestd;//最长连续增加子串inta[100],dp[100],maxn=0;intmain()......
  • 扁平数组转tree
    扁平数组转tree需要用到的测试数据letflatArr=[{id:1,title:'标题1',parent_id:0},{id:2,title:'标题2',parent_id:0},{id:3,title:'标题2-1',......
  • 算法16:归并排序_相关面试题 (超难)
    归并排序(MergeSort)就是利用归并的思想实现排序方法。它的原理是假设初始序列含义n个记录,则可以看成是n个有序子序列,每个序列的长度为1,然后两两归并,得到【n/2】([x]表示不......
  • 【Django drf】认证类 权限类 频率类 过滤类 排序类 分页类
    目录认证类前期准备自定义认证类配置认证类全局配置局部禁用认证组件使用步骤基于类中方法的认证(了解)权限类前期准备重写has_permission()添加权限不足信息权限组件使用......
  • 02.java基础(一)java的基础、方法和数组
    目录Java基础Java特性Java程序运行机制Java基础语法1.数据类型基本类型引用类型数据类型扩展String类型内存分配过程转义字符类型转换变量常量2.运算符逻辑运算符、位运算......