У меня есть такой объект:
Object {a: 1, b: 2, undefined: 1}
Как мне быстро извлечь из него идентификатор с наибольшим значением (здесь b
:)? Я попытался преобразовать его в массив, а затем отсортировать, но это не сработало, так как он был отсортирован по алфавиту (и кажется излишним жонглировать данными взад и вперед только для получения одного значения из трех).
javascript
Томек Бушевски
источник
источник
2
илиb
как результатb
;-)Ответы:
Например:
var obj = {a: 1, b: 2, undefined: 1}; Object.keys(obj).reduce(function(a, b){ return obj[a] > obj[b] ? a : b });
В ES6 :
var obj = {a: 1, b: 2, undefined: 1}; Object.keys(obj).reduce((a, b) => obj[a] > obj[b] ? a : b);
источник
c, d, e... x
.2
тому жеb
?var obj = {a: 1, b: 2, c: 2}, keys = Object.keys(obj), largest = Math.max.apply(null, keys.map(x => obj[x])) result = keys.reduce((result, key) => { if (obj[key] === largest){ result.push(key); } return result; }, []);
Использование Underscore или Lo-Dash:
var maxKey = _.max(Object.keys(obj), function (o) { return obj[o]; });
С функциями стрелок ES6:
var maxKey = _.max(Object.keys(obj), o => obj[o]);
демонстрация jsFiddle
источник
var maxKey = _.maxBy(_.keys(obj), function (o) { return obj[o]; });
.Вот предложение на случай, если у вас много одинаковых значений, а не только один максимум:
const getMax = object => { return Object.keys(object).filter(x => { return object[x] == Math.max.apply(null, Object.values(object)); }); };
Это возвращает массив с ключами для всех из них с максимальным значением, на случай, если некоторые из них имеют равные значения. Например: если
Если же есть максимум:
источник
object
это аргумент, который принимает функция выше, это синтаксис ES6 для определения функций, эквивалентный:,function getMax(object)
это отвечает на ваш вопрос?Предположим, у вас есть
Object
такое:var obj = {a: 1, b: 2, undefined: 1}
Ты можешь это сделать
var max = Math.max.apply(null,Object.keys(obj).map(function(x){ return obj[x] })); console.log(Object.keys(obj).filter(function(x){ return obj[x] == max; })[0]);
источник
Очень простой метод. может быть медленным для обработки
var v = {a: 1, b: 2, undefined: 1}; function geth(o){ var vals = []; for(var i in o){ vals.push(o[i]); } var max = Math.max.apply(null, vals); for(var i in o){ if(o[i] == max){ return i; } } } console.log(geth(v));
источник
const data = { abc: '', myShortKey: '', myVeryLongKey: '' } const longestKeyLength = Math.max(...Object.keys(data).map((d) => d.length)); console.log(longestKeyLength); console.log(Object.entries(data).map(([key, val]) => `${key}: ${key.length}`));
источник