我有一个REST
查询返回的数组,它表示多步生产过程中的项目数。
var steps = [
{ name:'Package', value:3},
{ name:'Assemble', value:1 },
{ name:'Ship', value:7},
{ name:'Preprocess', value:9 },
{ name:'Paint', value:5 }
];
我想按流程的顺序对它们进行排序,如下所示:
我使用Underscore进行其他字母数字排序,但是我无法弄清楚。
答案 0 :(得分:2)
您可以为所需订单获取一个带有位置数值的对象。然后按此值排序。
var steps = [{ name: 'Package', value: 3 }, { name: 'Assemble', value: 1 }, { name: 'Ship', value: 7 }, { name: 'Preprocess', value: 9 }, { name: 'Paint', value: 5 }],
order = { Preprocess: 1, Paint: 2, Assemble: 3, Package: 4, Ship: 5 };
steps.sort(({ name: a }, { name: b }) => order[a] - order[b]);
console.log(steps);
.as-console-wrapper { max-height: 100% !important; top: 0; }
答案 1 :(得分:0)
您可以创建一个对象,该对象在订购时会提及每个名称的优先级。
let priority = {
Preprocess: 1,
Paint: 2,
Assemble: 3,
Package: 4,
Ship: 5,
}
var steps = [
{ name:'Package', value:3},
{ name:'Assemble', value:1 },
{ name:'Ship', value:7},
{ name:'Preprocess', value:9 },
{ name:'Paint', value:5 }
];
const result = steps.sort((a,b) => priority[a.name] - priority[b.name]);
console.log(result);
答案 2 :(得分:0)
我只是对每种步骤类型都使用一个优先级映射,以便可以在比较功能中使用它。
var steps = [
{ name: 'Package', value: 3 },
{ name: 'Assemble', value: 1 },
{ name: 'Ship', value: 7 },
{ name: 'Preprocess', value: 9 },
{ name: 'Paint', value: 5 }
];
var stepPrecedenceMap = new Map([["Preprocess", 1], ["Paint", 2], ["Assemble", 3], ["Package", 4], ["Ship", 5]])
console.log(
steps.sort((stepA, stepB) => {
return stepPrecedenceMap.get(stepA.name) - stepPrecedenceMap.get(stepB.name)
}));