A melhor abordagem para o caso específico aqui, em minha opinião, é aquela sugerida pelo commonpike . Uma pequena melhoria que eu sugiro que funciona em navegadores modernos é:
Object.keys(aao).sort(function(a,b){return aao[b]-aao[a]});
Isso pode se aplicar facilmente e funcionar muito bem no caso específico aqui, para que você possa fazer:
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){
}
Além disso, apresento aqui uma função mais "genérica" que você pode usar para classificar até mesmo em uma gama mais ampla de situações e que mistura a melhoria que acabei de sugerir com as abordagens das respostas de Ben Blank (classificando também valores de string) e PopeJohnPaulII ( classificação por campo / propriedade de objeto específico) e permite que você decida se deseja uma ordem ascendente ou descendente, aqui está:
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});
}
}
}
Você pode testar as funcionalidades tentando algo como o seguinte código:
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));
Como eu já disse, você pode fazer um loop sobre as chaves classificadas se precisar fazer outras coisas
let sk=sortedKeys(aoo);
for (let i=sk.length-1;i>=0;--i){
}
Por último, mas não menos importante, algumas referências úteis a Object.keys e Array.sort