将Js数组对象中的某个属性值升序排序,并指定数组中的某个对象移动到数组的最前面
需求整理:
本篇文章主要实现的是将一个数组的中对象的属性值通过升序的方式排序,然后能够让程序可以指定对应的数组对象移动到程序的最前面。
数组如下所示:
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 }]
作者名称:追逐时光者
作者简介:一个热爱编程、善于分享、喜欢学习、探索、尝试新事物和新技术的全栈软件工程师。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。如果该篇文章对您有帮助的话,可以点一下右下角的【♥推荐♥】,希望能够持续的为大家带来好的技术文章,文中可能存在描述不正确的地方,欢迎指正或补充,不胜感激。