JavaScript自定义数组排序方法
作者:bea
本文实例讲述了JavaScript自定义数组排序方法。分享给大家供大家参考。具体分析如下: Array中有自带的排序功能,这个使用起来比较方便,我们有一点必须清楚,就是排序的依据,如果sort不传入参数的话,那就是按照字符编码(Unicode编码)的顺序排序。 var a=["3","2","1"]; console.log(a[0].charCodeAt(0)); // 51 console.log(a[1].charCodeAt(0)); // 50 console.
本文实例讲述了JavaScript自定义数组排序方法。分享给大家供大家参考。具体分析如下:
Array中有自带的排序功能,这个使用起来比较方便,我们有一点必须清楚,就是排序的依据,如果sort不传入参数的话,那就是按照字符编码(Unicode编码)的顺序排序。
var a=["3","2","1"];
console.log(a[0].charCodeAt(0)); // 51
console.log(a[1].charCodeAt(0)); // 50
console.log(a[2].charCodeAt(0)); // 49
console.log(a.sort()); // ["1", "2", "3"]
var a=["3","你","他"];
console.log(a[0].charCodeAt(0)); // 51
console.log(a[1].charCodeAt(0)); // 20320
console.log(a[2].charCodeAt(0)); // 20182
console.log(a.sort()); // ["3", "他", "你"]
var a=["3","11","222"];
console.log(a.sort());// ["11", "222", "3"]
// 多个字符的时候按照第一个字符的编码
不过我觉得sort最好用的地方在于可以自定义排序,这个在实际运用中也比较常见,比如要对对象数组排序。例如线面的一个对象数组,要根据其中的某一个字段进行排序,当然自己也可以写个函数来完成,不过我想没有sort来得方便。
var list = [
{
max:3,
avg:2,
min:1
},
{
max:10,
avg:15,
min:20
},
{
max:8,
avg:5,
min:2
}
];
// 根据max字段对list对象进行排序,从小到大的顺序
// x,y就是要比较的数组的单个元素,这里就是list中的一个元素
// 排序方法主要是要提供一个比较大小的规则,换句话说也就是要说明谁大谁小
// 返回值为true or false
function sortByField(x, y) {
return x.max - y.max;
}
console.log(list.sort(sortByField));
运行效果如下图所示:
希望本文所述对大家的javascript程序设计有所帮助。
猜你喜欢
您可能感兴趣的文章:
- JS弹出可拖拽可关闭的div层完整实例
- AngularJS表单编辑提交功能实例
- javascript转换日期字符串为Date日期对象的方法
- jQuery动态修改超链接地址的方法
- jQuery实现contains方法不区分大小写的方法
- javascript获取元素离文档各边距离的方法
- jQuery点缩略图弹出层显示大图片
- Js控制滑轮左右滑动实例
- JavaScript函数作用域链分析
- JavaScript匿名函数用法分析
- js实现进度条的方法
- NodeJs基本语法和类型
- 动态加载js的方法汇总
- jQuery EasyUI datagrid实现本地分页的方法
- jQuery向后台传入json格式数据的方法
- 浅谈轻量级js模板引擎simplite
- js实现拖拽效果
- jQuery多个input求和的实现方法
- JQuery实现防止退格键返回的方法