博客
关于我
将Js数组对象中的某个属性值升序排序,并指定数组中的某个对象移动到数组的最前面
阅读量:408 次
发布时间:2019-03-05

本文共 1523 字,大约阅读时间需要 5 分钟。

需求整理

本篇文章主要实现的是将一个数组中的对象属性值通过升序方式排序,并能够指定对应的数组对象移动到程序的最前面。

数组如下所示:

var arrayData= [{name: "夏明", Id:24}, {name: "小红", Id: 25},{name: "大袁", Id: 22},{name: "大姚", Id: 23},{name: "小芳", Id: 18}];

首先将数组中的Id值通过升序方式排序:

//源数组var arrayData= [{name: "夏明", Id:24}, {name: "小红", Id: 25},{name: "大袁", Id: 22},{name: "大姚", Id: 23},{name: "小芳", Id: 18}];
//重写排序方法var compare = function (attribute) { return function (obj1, obj2) { var val1 = obj1[attribute]; var val2 = obj2[attribute]; if (val1 < val2) { return -1; } else if (val1 > val2) { return 1; } else { return 0; } } var newArrayData=arrayData.sort(compare('Id')); //通过Id排序完成后的数组console.log(newArrayData);

排序完成后输出的值:

[{ name: "大袁", Id: 22 },  { name: "大姚", Id: 23 }, { name: "夏明", Id: 24 },{ name: "小红", Id: 25 }]

找到Id为23的对象,移动到数组的最前面去(注意Id值唯一):

实现原理:因为移除数组对象需要找到对应数组对象的下标索引才能进行移除,现在我们需要移除Id=23的对象,让其排到最前面去(先找到对象下标,然后把给数组对象赋值给temporaryArry临时数组,然后在通过下标移除newArrayData中的该对象值,最后将arrayData等于temporaryArry.concat(newArrayData)重新渲染数组数据)。

代码实现:

//创建临时数组var  temporaryArry=[];//找到数组中Id=23的下标索引(从0开始)let currentIdx=newArrayData.findIndex(v=>v.Id==23);console.log('Id=23的索引值为:',currentIdx);//把Id=23的对象赋值给临时数组temporaryArry.push(newArrayData[currentIdx]);//移除数组newArray中Id=23的对象newArrayData.splice(currentIdx,1);//从start[一般为对象的索引]的位置开始向后删除delCount个元素console.log('移除后的数据',newArrayData);//重新渲染数组newArrayData=temporaryArry.concat(newArrayData);	console.log(newArrayData);

输出结果:

[{ name: "大姚", Id: 23 }, { name: "小芳", Id: 18 }, { name: "大袁", Id: 22 }, { name: "夏明", Id: 24 },{ name: "小红", Id: 25 }]

转载地址:http://yqozz.baihongyu.com/

你可能感兴趣的文章
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>
Oracle——08PL/SQL简介,基本程序结构和语句
查看>>
oracle下的OVER(PARTITION BY)函数介绍
查看>>
Oracle中DATE数据相减问题
查看>>
Oracle中merge into的使用
查看>>
oracle中sql的case语句运用--根据不同条件去排序!
查看>>
oracle中关于日期问题的汇总!
查看>>
Oracle中常用的语句
查看>>
oracle典型安装失败,安装oracle 10失败
查看>>
oracle系统 介绍,ORACLE数据库管理系统介绍
查看>>
oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
查看>>
org.apache.poi.hssf.util.Region
查看>>
org/hibernate/validator/internal/engine
查看>>
orm总结
查看>>
paddle的两阶段基础算法基础
查看>>
SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
查看>>
pageHelper分页工具的使用
查看>>