Najlepszym rozwiązaniem dla przypadku szczególnego tutaj, moim zdaniem, jest jednym commonpike sugerowane. Małe ulepszenie, które proponuję, które działa w nowoczesnych przeglądarkach to:
Object.keys(aao).sort(function(a,b){return aao[b]-aao[a]});
Można to łatwo zastosować i świetnie działać w konkretnym przypadku tutaj, więc możesz:
let aoo={};
aao["sub2"]=1;
aao["sub0"]=-1;
aao["sub1"]=0;
aao["sub3"]=1;
aao["sub4"]=0;
let sk=Object.keys(aao).sort(function(a,b){return aao[b]-aao[a]});
for (let i=sk.length-1;i>=0;--i){
}
Poza tym, podaję tutaj bardziej "ogólną" funkcję, której możesz użyć do sortowania nawet w szerszym zakresie sytuacji i która łączy poprawę, którą właśnie zasugerowałem, z podejściem do odpowiedzi Bena Blanka (sortowanie również wartości ciągów) i PopeJohnPaulII ( sortowanie według określonego pola / właściwości obiektu) i pozwala zdecydować, czy chcesz uzyskać kolejność rosnącą, czy podrzędną, oto ona:
function sortedKeys(aao,comp="",intVal=false,desc=false){
let keys=Object.keys(aao);
if (comp!="") {
if (intVal) {
if (desc) return keys.sort(function(a,b){return aao[b][comp]-aao[a][comp]});
else return keys.sort(function(a,b){return aao[a][comp]-aao[a][comp]});
} else {
if (desc) return keys.sort(function(a,b){return aao[b][comp]<aao[a][comp]?1:aao[b][comp]>aao[a][comp]?-1:0});
else return keys.sort(function(a,b){return aao[a][comp]<aao[b][comp]?1:aao[a][comp]>aao[b][comp]?-1:0});
}
} else {
if (intVal) {
if (desc) return keys.sort(function(a,b){return aao[b]-aao[a]});
else return keys.sort(function(a,b){return aao[a]-aao[b]});
} else {
if (desc) return keys.sort(function(a,b){return aao[b]<aao[a]?1:aao[b]>aao[a]?-1:0});
else return keys.sort(function(a,b){return aao[a]<aao[b]?1:aao[a]>aao[b]?-1:0});
}
}
}
Możesz przetestować funkcje, próbując czegoś takiego jak poniższy kod:
let items={};
items['Edward']=21;
items['Sharpe']=37;
items['And']=45;
items['The']=-12;
items['Magnetic']=13;
items['Zeros']=37;
console.log("1: "+sortedKeys(items));
console.log("2: "+sortedKeys(items,"",false,true));
console.log("3: "+sortedKeys(items,"",true,false));
console.log("4: "+sortedKeys(items,"",true,true));
items={};
items['k1']={name:'Edward',value:21};
items['k2']={name:'Sharpe',value:37};
items['k3']={name:'And',value:45};
items['k4']={name:'The',value:-12};
items['k5']={name:'Magnetic',value:13};
items['k6']={name:'Zeros',value:37};
console.log("1: "+sortedKeys(items,"name"));
console.log("2: "+sortedKeys(items,"name",false,true));
Jak już powiedziałem, możesz zapętlić posortowane klucze, jeśli potrzebujesz coś zrobić
let sk=sortedKeys(aoo);
for (let i=sk.length-1;i>=0;--i){
}
Na koniec kilka przydatnych odniesień do Object.keys i Array.sort