sort()
对数组的元素进行从小到大来排序(会改变原来的数组)
sort()方法举例:无参时
如果在使用 sort() 方法时不带参,则默认按照Unicode编码,从小到大进行排序
var arr1 = ["e", "b", "d", "a", "f", "c"];
var result1 = arr1.sort();
var arr2 = [5, 2, 11, 3, 4, 1];
var result2 = arr2.sort();
console.log("arr1 =" + JSON.stringify(arr1));
console.log("result1 =" + JSON.stringify(result1));
console.log("arr2 =" + JSON.stringify(arr2));
console.log("result2 =" + JSON.stringify(result2));
可以看出使用 sort() 排序后,会改变原数组
而在排数字时也会有点问题,因为默认是按照Unicode编码进行排序的
sort()方法举例:带参时
如果在 sort()方法中带参,我们就可以自定义排序规则
具体方法:
可以在sort()添加一个回调函数,来指定排序规则
回调函数中需要定义两个形参,浏览器将会分别使用数组中的元素作为实参去调用回调函数
浏览器根据回调函数的返回值来决定元素的排序:(重要)
- 如果返回一个大于0的值,则元素会交换位置
- 如果返回一个小于0的值,则元素位置不变
- 如果返回一个0,则认为两个元素相等,则不交换位置
var arr = [5, 2, 11, 3, 4, 1];
var result = arr.sort(function (a, b) {
if (a > b) {
// 如果 a 大于 b,则交换 a 和 b 的位置
return 1;
} else if (a < b) {
// 如果 a 小于 b,则位置不变
return -1;
} else {
// 如果 a 等于 b,则位置不变
return 0;
}
});
console.log("arr =" + JSON.stringify(arr));
console.log("result =" + JSON.stringify(result));
优化:
//冒泡排序
var arr = [5, 2, 11, 3, 4, 1];
var result = arr.sort(function (a, b) {
return a - b;
});
console.log("arr =" + JSON.stringify(arr));
console.log("result =" + JSON.stringify(result));
运行结果与上图一致