使用 lodash/underscore.js 从数组中获取对象属性和值

Get object properties and values from array using lodash/underscore.js

本文关键字:取对象 获取 属性 数组 lodash underscore js 使用      更新时间:2023-09-26

小提琴示例

我有一个这样的数组:

var array = [ { 
    'data-price': '0.00',
    'data-term': '532',
    'data-model_id': '409',
  },
  { 
    'data-price': '0.00',
    'data-term': '483',
    'data-model_id': '384',
  },
  { text: 'dffdfddgfdgf' } ];

我想过滤掉最后一个对象并从前两个对象中提取[{data-model_id:409},{data-model_id:384}]。我试过这段代码:

 var k = _(array).filter('data-model_id').pluck('data-model_id').value();
console.log(k);

它只返回一个值的数组,["409", "384"] .是否有一个函数可以在 lodash 或下划线中返回整个对象?

使用纯JS来显示逻辑:您需要filter出没有键的元素,然后将新集合map为另一种形式:

array.filter( function(item){
    return 'data-model_id' in item;
  }).map( function( item ){
    return { 'data-model_id' : item['data-model_id'] }
  });

http://jsfiddle.net/dn4tn6xv/7/

如果我告诉你这只使用原生 JavaScript 是可能的呢?只需使用 Array.filterObject.keys ,使用前者进行过滤,后者获取密钥,然后通过比较返回的Array索引来返回Boolean Object.keys

var k = array.filter(function(obj){
   return Object.keys(obj).indexOf("data-model_id") > -1;
});

lodash中,您可以这样做:

获取完整对象

console.log(_.filter(array, 'data-model_id'));

仅获取data-model_id属性

var res = _.chain(array).filter('data-model_id').map(function (el) {
  return _.pick(el, 'data-model_id');
}).value();