我有一个对象:
const animals = [
{name: 'Fluffy', species: 'cat'},
{name: 'Crinkle', species: 'rabbit'},
{name: 'Wally', species: 'dog'},
{name: 'Roo', species: 'dog'},
{name: 'Felix', species: 'cat'},
]我想使用一个更高阶的函数,比如filter()方法来获取动物对象的数组,并返回一个只包含所有狗的名字的数组,即["Wally", "Roo"]。目前,我的代码返回一个包含整个对象的数组,其中包含物种狗。如下所示:
const dogArray = animals.filter(function(animal) {
return animal.species === 'dog';
})
return dogArray;
// returns
// [{name: "Wally", species: "dog"},
// { name: "Roo", species: "dog"}]发布于 2018-08-21 20:44:23
只需将过滤数组的元素映射到它们的name属性:
const animals = [
{name: 'Fluffy', species: 'cat'},
{name: 'Crinkle', species: 'rabbit'},
{name: 'Wally', species: 'dog'},
{name: 'Roo', species: 'dog'},
{name: 'Felix', species: 'cat'},
]
const dogArray = animals.filter(animal => animal.species === 'dog');
console.log(dogArray.map(dog => dog.name));
或者将这两个合并为一个reduce:
const animals = [
{name: 'Fluffy', species: 'cat'},
{name: 'Crinkle', species: 'rabbit'},
{name: 'Wally', species: 'dog'},
{name: 'Roo', species: 'dog'},
{name: 'Felix', species: 'cat'},
]
let dogArray = animals.reduce((dogs, animal) => {
if (animal.species === "dog") dogs.push(animal.name);
return dogs;
}, []);
console.log(dogArray)
发布于 2018-08-21 20:45:39
您可以使用destructuring映射该属性。
const
animals = [{ name: 'Fluffy', species: 'cat' }, { name: 'Crinkle', species: 'rabbit' }, { name: 'Wally', species: 'dog' }, { name: 'Roo', species: 'dog' }, { name: 'Felix', species: 'cat' }]
dogArray = animals
.filter(({ species }) => species === 'dog')
.map(({ name }) => name);
console.log(dogArray);
发布于 2018-08-21 20:45:08
创建一个空数组,使用for循环遍历现有的dogArray,将名称推入新的数组,然后返回新的数组。
const dogArray = animals.filter(function(animal) {
return animal.species === 'dog';
})
let dogNames = [];
for (let i in dogArray) {
dogNames.push(dogArray[i].name);
}
return dogNames;https://stackoverflow.com/questions/51948940
复制相似问题