Как отфильтровать ключи объекта с помощью lodash?

179

У меня есть объект с некоторыми ключами, и я хочу сохранить только некоторые ключи с их значением?

Я пробовал с filter:

const data = {
  aaa: 111,
  abb: 222,
  bbb: 333
};

const result = _.filter(data, (value, key) => key.startsWith("a"));

console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>

Но он печатает массив:

[111, 222]

Что не то, что я хочу.

Как это сделать с lodash? Или что-то еще, если lodash не работает?

Freewind
источник

Ответы:

285

У Lodash есть _.pickByфункция, которая делает именно то, что вы ищете.

var thing = {
  "a": 123,
  "b": 456,
  "abc": 6789
};

var result = _.pickBy(thing, function(value, key) {
  return _.startsWith(key, "a");
});

console.log(result.abc) // 6789
console.log(result.b)   // undefined
<script src="https://cdn.jsdelivr.net/lodash/4.16.4/lodash.min.js"></script>

serg10
источник
9
Кажется, это не работает в версии 4 lodash, и новый предикат _.pickBy вызывается только со значением, а не ключом. Boo :( ... Я полагаю, вы можете связать _.pick и _.pickBy (на самом деле нет, вы не можете получить ту же функциональность)
SDK
3
Это больше не работает с последней версии Lodash, только к вашему сведению
Eudis Duran
8
@EudisDuran вы должны использовать.pickBy
apfelbox
Похоже, что было исправлено с последней версией
39

Просто измените фильтр на omitBy

const data = { aaa: 111, abb: 222, bbb: 333 };
const result = _.omitBy(data, (value, key) => !key.startsWith("a"));
console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>

Кристиан Янковский
источник
Разве это не печатает массив?
Mr_Green
4
Спасибо! И я думаю, что мы можем использовать_.pick
Freewind
Это больше не работает с последней версии, только к вашему сведению
Eudis Duran
18

Вот пример использования lodash4.x:

const data = {
  aaa: 111,
  abb: 222,
  bbb: 333
};

const result = _.pickBy(data, (value, key) => key.startsWith("a"));

console.log(result);
// Object { aaa: 111, abb: 222 }
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>
<strong>Open your javascript console to see the output.</strong>

PaulMest
источник
4

Не-lodash способ решить это довольно читабельным и эффективным способом:

function filterByKeys(obj, keys = []) {
  const filtered = {}
  keys.forEach(key => {
    if (obj.hasOwnProperty(key)) {
      filtered[key] = obj[key]
    }
  })
  return filtered
}

const myObject = {
  a: 1,
  b: 'bananas',
  d: null
}

const result = filterByKeys(myObject, ['a', 'd', 'e']) // {a: 1, d: null}
console.log(result)

thomax
источник