描述:很多时候,前端会拿到[{time:‘2020-10-10’},{time:‘2020-10-11’},{time:‘2020-10-12’}…]类似的数据,然后去渲染页面,但是需求中要求升序或者降序渲染:
既有如下方法:结合Array.sort() 使用
Array.sort(getTimeSortByObjPropUp(‘排序依据的属性’)):
说明:因为array.sort(func)
sort 方法需要传入一个函数 like:
function(a, b) {
return a - b
}
下面的处理方法在此基础上进行升级,用闭包处理后再加入到sort方法中,一次来完成对象数组,按子项的某个属性进行排序的功能;
(一下方法适合处理以时间字符串属性为依据的排序,如果是依据其他值类型 ,稍作修改a和b即可实现)
export const getTimeSortByObjPropUp = (key) => {
return (ahead, behind) => { //ahead 前一个对象 behind后一个对象
let a = +new Date(ahead[key])
let b = +new Date(behind[key])
return b - a
}
}