一、普通数组的排序

js中用方法sort()为数组排序。sort()方法有一个可选参数,是用来确定元素顺序的函数。如果这个参数被省略,那么数组中的元素将按照ASCII字符顺序进行排序。如:

 let arr = ['A','C','B','D']
 arr.sort()
 console.log(arr) // ['A','B','C','D']

如果一个数组元素是数字,此时还是用sort()为数组排序,先看看效果如何:

 let arr = [15,8,25,3]
 arr.sort()
 console.log(arr) // [15,25,3,8]

怎么没有起到效果(按大小排序),其实,sort方法会调用每个数组项的toString()方法,得到字符串,然后再对得到的字符串进行排序。虽然数值15比3大,但在进行字符串比较时"15"则排在"3"前面(ASCII字符顺序)。显然,这种结果不是我们想要的,这时,sort()方法的参数就起到了作用,我们把这个参数叫做比较函数。

 let arr = [15,8,25,3]
 arr.sort((x,y)=> x - y) // 正序
 console.log(arr) // [3,8,15,25]
 arr.sort((x,y)=> y - x) // 倒序

比较函数接收两个参数,如果第一个参数应该位于第二个之前则返回一个负数,如果两个参数相等则返回0,如果第一个参数应该位于第二个之后则返回一个正数。

二、数组内对象排序

数组项是对象,需要根据数组项的某个属性对数组进行排序。

let person = [
	{name:'zs',age:22},
	{name:'ls',age:20},
	{name:'ww',age:28},
]
// 如果我们需要按照对象中的age属性进行数组排序
person.sort((a,b)=>{
	return a.age - b.age
})
console.log(person) // [{name:'ls',age:20},{name:'zs',age:22},{name:'ww',age:28},]
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐