从对象中提取每个属性的 1
Extract 1 of each property from object
我正在寻找一种使用 lodash/underscore(如果不存在,则为纯 JS)的方法,该方法只有我才能接受如下所示的给定对象。
animals: {
{
type: 'duck',
name: 'quack',
},
{
type: 'duck',
name: 'quieck',
},
{
type: 'dog',
name: 'bark',
},
},
例如,这个对象包含 3 种不同的动物,但其中两种是相同的类型。
最终结果是能够使用诸如 for 循环之类的控制结构来迭代每种类型的动物,这样我正在使用只有每种类型一个实例的东西。
之所以使用此功能,是因为我正在创建一个列表。
此列表将类似于以下内容
duck
name is quack
name is quick
dog
name is bark
但我想用控制结构来做到这一点,而不是简单地在每个名称中输出和硬编码,因为这个列表会变得非常广泛和冗长。
我会使用 uniq 函数。
var uniqueAnimals = _.uniq(animals, function(item, key, type) {
return item.type;
});
假设animals
不是语法错误,而是一个数组: 如果您不仅要过滤唯一类型,还要为输出创建结构,则可以使用对象:
var kv = {};
animals.forEach(function(a) {
if(kv[a.type]) {
kv[a.type].push(a.name);
} else {
kv[a.type] = [];
}
}
稍后,您可以迭代Object.keys(kv)
以打印键/值
_.groupBy() 也许?
var animals = [
{
type: 'duck',
name: 'quack',
},
{
type: 'duck',
name: 'quieck',
},
{
type: 'dog',
name: 'bark',
},
];
var grouped = _.groupBy(animals, 'type');
document.write('<pre>' + JSON.stringify(grouped, null, 3) + '</pre>');
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.6.1/lodash.min.js"></script>
相关文章:
- 为什么我可以在Array属性对象中找到Javascript Array for Each方法
- 使用onclick调用属性对象函数
- 嵌套为..in 循环,列出多维对象的属性(对象)
- 动态属性对象 - JSON
- 在不使用隔离范围angularjs自定义指令的情况下获取属性对象
- 通过属性传递属性/对象.Javascript
- Javascript:属性/对象的类型
- 访问JSON中的属性(对象)
- 属性对象Javascript不是用Jquery Deferred设置的
- 无法读取属性'#<对象>'未定义的获取错误
- Twitter中多属性对象的子字符串匹配
- 无法设置'data'属性'对象'标记.(只IE8)
- 更新数据属性对象属性值
- 将属性对象的选定对象从原型推入数组
- 将单个属性对象字面量的数组转换为仅包含其值的数组的最佳方法
- 寻找一种更简单的方法来检查是否多个属性&对象中的方法是未定义的
- 主干模型:带有get方法的空属性,但在属性对象中
- 如何赋值给"text"someText"属性对象在动能js
- Angularjs的数据绑定与数据属性对象
- 如何将一个嵌套的javascript对象转换为只有一级属性对象