前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS-比较函数中嵌套函数,可以排序【对象数组】

JS-比较函数中嵌套函数,可以排序【对象数组】

作者头像
xing.org1^
发布2018-05-17 16:21:46
4.8K0
发布2018-05-17 16:21:46
举报
文章被收录于专栏:前端说吧前端说吧
代码语言:javascript
复制
 1 function createCompareFun(propertyName){
 2                 return function(object1,object2){
 3                     var value1 = object1[propertyName];
 4                     var value2 = object2[propertyName];
 5                     if(value1>value2){
 6                         return 1;
 7                     }else if(value1<value2){
 8                         return -1;
 9                     }else{
10                         return 0;
11                     }
12                 };
13             }
14             var data = [{
15                 name : "guo",
16                 age : 23
17             },{
18                 name : "zhao",
19                 age : 28
20             },{
21                 name : "zhang",
22                 age : 24
23             }];
24             
25             data.sort(createCompareFun("name"));
26             document.write("<hr/>用name排序,获得的第二位的元素的name值是:【"+data[1].name+"】");
27             data.sort(createCompareFun("age"));
28             document.write("<br/>用age进行排序,获得的最后一个元素的name是:【"+data[2].name+"】")
29             

说明:createCompareFun()函数内部,嵌套一个内部函数,函数作为值被return返回,

内部函数传两个参数,并通过[]讲createCompareFun()函数的propertyName属性解析出来,在通过常规比较函数进行判断、比较。

在data中,定义了一个有三个元素的对象数组,最后调用createCompareFun()函数,并根据自己需要比较的属性来传参,函数对数组进行排序。得到比较的结果。

再加一个普通的比较函数

代码语言:javascript
复制
 1                     function compare(value1,value2){
 2                 if(value1>value2){
 3                     return 1;
 4                 }else if(value1<value2){
 5                     return -1;
 6                 }else{
 7                     return 0;
 8                 }
 9             }
10             var arrM = [1,325,6,74,2]
11             console.log(arrM.sort(compare));        
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-03-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档