¿Cómo filtrar las claves de un objeto con lodash?

178

Tengo un objeto con algunas claves y solo quiero conservar algunas de sus claves con su valor.

Lo intenté con 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>

Pero imprime una matriz:

[111, 222]

Que no es lo que quiero.

¿Cómo hacerlo con lodash? ¿O algo más si lodash no funciona?

Viento libre
fuente

Respuestas:

285

Lodash tiene una _.pickByfunción que hace exactamente lo que estás buscando.

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
fuente
9
Parece que esto está roto en la versión 4 de lodash, y el nuevo predicado _.pickBy solo se invoca con valor, no con clave. Boo :( ... supongo que puedes encadenar _.pick y _.pickBy (en realidad no, no puedes obtener la misma funcionalidad)
SDK
3
Esto ya no funciona a partir del último Lodash, solo un FYI
Eudis Duran
8
@EudisDuran que tienes que usar.pickBy
apfelbox
parece haberse solucionado con la última versión
39

Simplemente cambie el filtro a omitir

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>

Krystian Jankowski
fuente
¿Esto todavía no imprime una matriz?
Mr_Green
44
¡Gracias! Y creo que podemos usar_.pick
Freewind
Esto ya no funciona a partir de la última lodash, solo un FYI
Eudis Duran
18

Aquí hay un ejemplo usando 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
fuente
4

Una forma no loda de resolver esto de una manera bastante legible y eficiente:

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
fuente