我有一個像下面這樣的物件陣列:
var data = [
{
name": "Name2",
"webOrderingEnabled": true,
"distance": 1.6989125091571928
},
{
"name": "Name3",
"webOrderingEnabled": false,
"distance": 1.9178283920396098
},
{
"name": "Name4",
"webOrderingEnabled": false,
"shutdown": {
"message": "",
"status": true
},
"distance": 6.94478210395609
},
{
"name": "Name1",
"webOrderingEnabled": true,
"shutdown": {
"message": "",
"status": false
},
"distance": 0.5368834377514055
}
]
我想對這個物件陣列進行排序 1.webOrderingEnabled 2.shutdown.status = false 3. 距離 挑戰是某些物件沒有關閉鍵,如果它不存在,請考慮將其打開,我嘗試了以下方法它沒有用給我
data.sort((a, b) => {
if (a.shutdown?.status && b.shutdown?.starus || !a.shutdown?.status && !b.shutdown?.status &&
a.webOrderingEnabled || b.webOrderingEnabled) {
return a.distance - b.distance;
}
if (a.shutdown?.status) {
return -1;
}
return 1;
});
預期的:
[{
"name": "Name1",
"webOrderingEnabled": true,
"shutdown": {
"message": "",
"status": false
},
"distance": 0.5368834377514055
},
{
"name": "Name2",
"webOrderingEnabled": true
"distance": 1.6989125091571928
},
{
"name": "Name3",
"webOrderingEnabled": false,
"distance": 1.9178283920396098
},
{
"name": "Name4",
"webOrderingEnabled": false,
"shutdown": {
"message": "",
"status": true
},
"distance": 6.94478210395609
}]
uj5u.com熱心網友回復:
一般來說,如果您想根據欄位 A、B、C(按此順序)對物件陣列進行排序,您只需執行以下操作:
if (a.A < b.A) return -1;
else if (a.A > b.A) return 1;
// otherwise a.A == b.A, so let's proceed with considering B now...
if (a.B < b.B) return -1;
else if (a.B > b.B) return 1;
// otherwise a.A == b.A && a.B == b.B, so let's proceed with considering C now...
if (a.C < b.C) return -1;
else if (a.C > b.C) return 1;
return 0;
在這里,您可以a.A < b.A將其視為用于比較單個屬性值的偽代碼,具體如何進行取決于型別。
所以你的代碼應該看起來像
// I assume by "consider to be store open" you mean shutdown.status === false
function getShutdownStatus(a) {
return a?.shutdown?.status || false;
}
data.sort((a, b) => {
// Use ! here because true > false but it seems you want true to come first
if (!a.webOrderingEnabled < !b.webOrderingEnabled) return -1;
else if (!a.webOrderingEnabled > !b.webOrderingEnabled) return 1;
const aShutdown = getShutdownStatus(a);
const bShutdown = getShutdownStatus(b);
if (aShutdown < bShutdown) return -1;
else if (aShutdown > bShutdown) return 1;
// otherwise compare by distance
if (a.distance < b.distance) return -1;
else if (a.distance > b.distance) return 1
return 0;
});
完成此作業后,您可以簡化代碼:
data.sort((a, b) => {
if (a.webOrderingEnabled != b.webOrderingEnabled) return b.webOrderingEnabled - a.webOrderingEnabled;
const aShutdown = getShutdownStatus(a);
const bShutdown = getShutdownStatus(b);
if (aShutdown != bShutdown) return aShutdown - bShutdown;
return a.distance - b.distance;
});
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/381707.html
標籤:javascript 数组 排序 筛选
上一篇:如何將串列切成不同長度的子串列
