js笔记四十二之sort深入研究
2018-06-08 本文已影响20人
uplyw
数组排序
var ary = [12,23,14,34,23,1,14,16,26,2];
// ary.sort(); // 只按第一位数字进行排序(只能排10以内的数字)
ary.sort(function(a,b){
return a-b;
})
console.log(ary) // [1, 2, 12, 14, 14, 16, 23, 23, 26, 34]
- 回调函数
把一个方法A当做参数值传递给另一个函数B, 然后在B执行的过程中, 我们随时根据需求让A方法执行;
function A(){
}
function B(fn){
fn();
fn();
fn();
}
B(A);
var ary = [12,23,14,34,23,1,14,16,26,2];
ary.sort(function(a,b){
console.log(a,b)
// 12 23
// 23 14
// 14 34
// 34 23
// 23 1
// 1 14
// 14 16
// 16 26
// 26 2
// a -> 每一次执行匿名函数的时候,找到数组中的当前项
// b -> 当前项的后一项
// return a-b; // -> 升序 如果a>b,返回的>0, a和b 交换位置
// return b-a; // -> 降序 如果b>a,返回的>0,a和b变换位置
// return 的值是一个 > 0 或 <= 0 如果大于0 让a和b交换位置,小于等于0原来位置不变
})
var ary = [12,23,14,34,23,1,14,16,26,2];
ary.sort(function(a,b){
return 1;
})
console.log(ary) // [2, 26, 16, 14, 1, 23, 34, 14, 23, 12]
// 不管a和b谁大, 每一次都返回一个恒大于零的数, 也就是每一次a和b都要交换位置, 最后的结果就是原有数组倒过来排列了
// 相当于reverse
二维数组
二维数组排序
var ary = [
{name:"李雷",age:18},
{name:"韩梅梅",age:16},
{name:"王二",age:23},
{name:"赵四",age:32}
]
// 给二维数组排序,按照年龄由小到大排序
ary.sort(function(a,b){
return a.age - b.age;
})
console.log(ary)
// {name: "韩梅梅", age: 16}
// {name: "李雷", age: 18}
// {name: "王二", age: 23}
// {name: "赵四", age: 32}
var ary = [
{name:"李雷",age:18},
{name:"韩梅梅",age:16},
{name:"王二",age:23},
{name:"赵四",age:32}
]
// 给二维数组排序,按照年龄由大到小排序
ary.sort(function(a,b){
return (a.age - b.age)*-1;
})
console.log(ary)
// {name: "韩梅梅", age: 16}
// {name: "李雷", age: 18}
// {name: "王二", age: 23}
// {name: "赵四", age: 32}
按姓名排序 localeCompare()
var ary = [
{name:"李雷",age:18},
{name:"韩梅梅",age:16},
{name:"王二",age:23},
{name:"赵四",age:32}
]
ary.sort(function(a,b){
return a.name.localeCompare(b.name);
})
console.log(ary)
// {name: "李雷", age: 18}
// {name: "王二", age: 23}
// {name: "赵四", age: 32}
// {name: "韩梅梅", age: 16}