Найкращий підхід для конкретного випадку тут, на мій погляд, це один commonpike запропонував. Трохи вдосконалення, яке я б запропонував, що працює в сучасних браузерах:
Object.keys(aao).sort(function(a,b){return aao[b]-aao[a]});
Це може бути застосовано легко і чудово працює в конкретному випадку тут, так що ви можете зробити:
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){
}
Окрім цього, я надаю тут більш "загальну" функцію, яку ви можете використовувати для сортування навіть у більш широкому діапазоні ситуацій, і це поєднує вдосконалення, яке я щойно запропонував, із підходами відповідей Бена Бланка (сортування також рядкових значень) та PopeJohnPaulII ( сортування за конкретним полем / властивістю об'єкта) і дозволяє вирішити, чи хочете ви порядок за зростанням чи спадком, ось він:
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});
}
}
}
Ви можете протестувати функціональні можливості, спробувавши щось на зразок такого коду:
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));
Як я вже говорив, ви можете перебирати відсортовані ключі, якщо вам потрібно робити речі
let sk=sortedKeys(aoo);
for (let i=sk.length-1;i>=0;--i){
}
Останнє, але не менш важливе, кілька корисних посилань на Object.keys та Array.sort