繁体   English   中英

循环遍历对象数组以创建列表数组

[英]Looping through an array of objects to create a list array

我无法从对象数组创建列表数组。 我不确定我哪里出错了。 这是我的问题:

查找所有设计师的所有鞋子,并使用以下格式将它们列在 arrays 数组中:

[[设计师姓名,鞋名,价格],[设计师姓名,鞋名,价格],....] 例如,

 const currentInventory = [ { name: 'Brunello Cucinelli', shoes: [ {name: 'tasselled black low-top lace-up', price: 1000}, {name: 'tasselled green low-top lace-up', price: 1100}, {name: 'plain beige suede moccasin', price: 950}, {name: 'plain olive suede moccasin', price: 1050} ] }, { name: 'Gucci', shoes: [ {name: 'red leather laced sneakers', price: 800}, {name: 'black leather laced sneakers', price: 900} ] } ]; function renderInventory(inventory) { let arr = []; for(let i = 0; i < inventory.length; i++) { for(let j = 0;j < inventory[i].shoes.length; j++) { arr.push([`${inventory[i].name}, ${inventory[i].shoes[j].name}, ${inventory[i].shoes[j].price}`]) } } return arr; }

我收到此错误,但不知道为什么?

Expected $[0].length = 1 to equal 3. Expected $[0][0] = 'Brunello Cucinelli, tasselled black low-top lace-up, 1000' to equal 'Brunello Cucinelli'. Expected $[0][1] = undefined to equal 'tasselled black low-top lace-up'. Expected $[0][2] = undefined to equal 1000. Expected $[1].length = 1 to equal 3. Expected $[1][0] = 'Brunello Cucinelli, tasselled green low-top lace-up, 1100' to equal 'Brunello Cucinelli'. Expected $[1][1] = undefined to equal 'tasselled green low-top lace-up'. Expected $[1][2] = undefined to equal 1100. Expected $[2].length = 1 to equal 3. Expected $[2][0] = 'Brunello Cucinelli, plain beige suede moccasin, 950' to equal 'Brunello Cucinelli'. Expected $[2][1] = undefined to equal 'plain beige suede moccasin'. Expected $[2][2] = undefined to equal 950. Expected $[3].length = 1 to equal 3. Expected $[3][0] = 'Brunello Cucinelli, plain olive suede moccasin, 1050' to equal 'Brunello Cucinelli'. Expected $[3][1] = undefined to equal 'plain olive suede moccasin'. Expected $[3][2] = undefined to equal 1050. Expected $[4].length = 1 to equal 3. Expected $[4][0] = 'Gucci, red leather laced sneakers, 800' to equal 'Gucci'. Expected $[4][1] = undefined to equal 'red leather laced sneakers'. Expected $[4][2] = undefined to equal 800. Expected $[5].length = 1 to equal 3. Expected $[5][0] = 'Gucci, black leather laced sneakers, 900' to equal 'Gucci'. Expected $[5][1] = undefined to equal 'black leather laced sneakers'. Expected $[5][2] = undefined to equal 900.

还,

我认为我也可以使用 .map() 和 .reduce() 来解决这个问题,但我不知道从哪里开始。

您需要检查长度

for(let j = 0; j < inventory[i].shoes.length; j++) {
               ^^^^

 const currentInventory = [ { name: 'Brunello Cucinelli', shoes: [ {name: 'tasselled black low-top lace-up', price: 1000}, {name: 'tasselled green low-top lace-up', price: 1100}, {name: 'plain beige suede moccasin', price: 950}, {name: 'plain olive suede moccasin', price: 1050} ] }, { name: 'Gucci', shoes: [ {name: 'red leather laced sneakers', price: 800}, {name: 'black leather laced sneakers', price: 900} ] } ]; function renderInventory(inventory) { let arr = []; for(let i = 0; i < inventory.length; i++) { for(let j = 0; j < inventory[i].shoes.length; j++) { arr.push([`${inventory[i].name}, ${inventory[i].shoes[j].name}, ${inventory[i].shoes[j].price}`]) } } return arr; } console.log(renderInventory(currentInventory));

更简单的方法是通过直接获取对象来使用for... of语句

 function renderInventory(inventory) { let arr = []; for (const { name, shoes } of inventory) for (const shoe of shoes) arr.push([`${name}, ${shoe.name}, ${shoe.price}`]); return arr; } const currentInventory = [{ name: 'Brunello Cucinelli', shoes: [{ name: 'tasselled black low-top lace-up', price: 1000 }, { name: 'tasselled green low-top lace-up', price: 1100 }, { name: 'plain beige suede moccasin', price: 950 }, { name: 'plain olive suede moccasin', price: 1050 }] }, { name: 'Gucci', shoes: [{ name: 'red leather laced sneakers', price: 800 }, { name: 'black leather laced sneakers', price: 900 }] }]; console.log(renderInventory(currentInventory));

在这一行中,您错过了比较

for(let j = 0; inventory[i].shoes.length; j++) {

写这个

   for(let j = 0;j < inventory[i].shoes.length; j++) {

 const currentInventory = [ { name: 'Brunello Cucinelli', shoes: [ {name: 'tasselled black low-top lace-up', price: 1000}, {name: 'tasselled green low-top lace-up', price: 1100}, {name: 'plain beige suede moccasin', price: 950}, {name: 'plain olive suede moccasin', price: 1050} ] }, { name: 'Gucci', shoes: [ {name: 'red leather laced sneakers', price: 800}, {name: 'black leather laced sneakers', price: 900} ] } ]; function renderInventory(inventory) { let arr = []; for(let i = 0; i < inventory.length; i++) { for(let j = 0; j < inventory[i].shoes.length; j++) { arr.push([inventory[i].name, inventory[i].shoes[j].name, inventory[i].shoes[j].price]) } } return arr; } console.log(renderInventory(currentInventory));

你需要这样写:

for(let i = 0; i < inventory.length-1; i++) {
    // code here
}

错误的原因是长度属性不一定表示数组中定义的值的数量。

let array = ['apple', 'banana'];

console.log(array.length);
// Expected result: 2

console.log(array[2]);
// Expected result: undefined

这就是最后一项未定义的原因。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM