对象数组内的数组迭代
Array iteration inside array of objects
我需要编写一个函数来遍历所有数组对象并检查是否至少一个对象具有内部数组,其中所有对象的布尔值都设置为 true。请参阅代码示例以更好地理解。
示例 1
const array = [
{
id: 1,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: false },
],
},
{
id: 2,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: false },
],
},
{
id: 3,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: true },
],
},
];
functionToBeCreated(array); // Output: true - because item with id 3 has innerArray where all items have "clicked: true".
示例 2
const array = [
{
id: 1,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: false },
],
},
{
id: 2,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: false },
],
},
{
id: 3,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: true },
],
},
];
functionToBeCreated(array); // Output: false - because no item has innerArray where all items have "clicked: true".
您是否知道如何实现它?
这样...
const ToBeCreated = arr =>
arr.some( el => el.innerArray.every(z => z.clicked));
const arrayTRUE =
[ { id: 1, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: false }
] }
, { id: 2, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: false }
] }
, { id: 3, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: true }
] } ]
const arrayFALSE =
[ { id: 1, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: false }
] }
, { id: 2, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: false }
] }
, { id: 3, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: true }
] } ]
// test
console.log( ToBeCreated(arrayTRUE ) )
console.log( ToBeCreated(arrayFALSE) )
我需要编写一个函数来遍历所有数组对象并检查是否至少一个对象具有内部数组,其中所有对象的布尔值都设置为 true。请参阅代码示例以更好地理解。
示例 1
const array = [
{
id: 1,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: false },
],
},
{
id: 2,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: false },
],
},
{
id: 3,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: true },
],
},
];
functionToBeCreated(array); // Output: true - because item with id 3 has innerArray where all items have "clicked: true".
示例 2
const array = [
{
id: 1,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: false },
],
},
{
id: 2,
innerArray: [
{ innerId: 1, clicked: true },
{ innerId: 2, clicked: false },
],
},
{
id: 3,
innerArray: [
{ innerId: 1, clicked: false },
{ innerId: 2, clicked: true },
],
},
];
functionToBeCreated(array); // Output: false - because no item has innerArray where all items have "clicked: true".
您是否知道如何实现它?
这样...
const ToBeCreated = arr =>
arr.some( el => el.innerArray.every(z => z.clicked));
const arrayTRUE =
[ { id: 1, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: false }
] }
, { id: 2, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: false }
] }
, { id: 3, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: true }
] } ]
const arrayFALSE =
[ { id: 1, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: false }
] }
, { id: 2, innerArray:
[ { innerId: 1, clicked: true }
, { innerId: 2, clicked: false }
] }
, { id: 3, innerArray:
[ { innerId: 1, clicked: false }
, { innerId: 2, clicked: true }
] } ]
// test
console.log( ToBeCreated(arrayTRUE ) )
console.log( ToBeCreated(arrayFALSE) )