二维数组如何按照名字排序
数组sort排序深入
通过利用Array原型中的sort方法,我们可以实现对数组进行排序,但是有兼容问题,在此我们不考虑兼容到ie6,7,以下内容只作为工作中的参考,如需获得兼容写法,可以@我:
- 需求1 使用sort方法对下面数组按照age进行排序
var ary = [
{name: "深圳",age: 40 },
{name: "北京",age: 140 },
{name: "广州",age: 70 },
{name: "上海",age: 400 },
{name: "珠海",age: 20 }
]
方法:
ary.sort(function(a, b) {
return parseFloat(a.age) - parseFloat(b.age)
})
console.log(ary)
结果:
Array(5)
0: {name: "珠海", age: 20}
1: {name: "深圳", age: 40}
2: {name: "广州", age: 70}
3: {name: "北京", age: 140}
4: {name: "上海", age: 400}
length: 5
__proto__: Array(0)
原理:
ary在数组原型中先找到sort方法, sort方法中是一个回调函数,里面有两个形参(a,b)
a代表当前项,b代表下一项
如果a-b >0 那么a就与b交换位置,反之保持原样,
- 需求2 使用sort方法对下面数组按照name进行排序
方法:
ary.sort(function(a, b) {
return (a.name.localeCompare(b.name))
})
console.log(ary)
结果:
(5) [{…}, {…}, {…}, {…}, {…}]
0: {name: "北京", age: 140}
1: {name: "广州", age: 70}
2: {name: "上海", age: 400}
3: {name: "深圳", age: 40}
4: {name: "珠海", age: 20}
length: 5
__proto__: Array(0)
原理:
1,对字符串进行排序,需要调用localCompare方法
2,语法:stringObject.localeCompare(target)
3,调用这个方法之后,会得到一个返回值(1,-1,0)
4,比较顺序是,先把中文转换成拼音,如果拼音也全部一样,再转换成ASCII码进行比较