ES6写法两次循环遍历一个二维数组,去校验最里面的对象值是否为空
时间: 2023-08-12 19:34:48 浏览: 178
ES6中可以使用数组的 `forEach` 方法来代替循环语句,简化代码。示例代码如下:
```javascript
const arr = [
[{name: 'Alice', age: 22}, {name: 'Bob', age: 30}],
[{name: 'Charlie', age: 25}, {name: 'David', age: 28}],
[{name: '', age: null}, {name: 'Eva', age: 24}]
];
arr.forEach((row, i) => {
row.forEach((obj, j) => {
if (!obj.name || !obj.age) {
console.log(`第 ${i} 行,第 ${j} 列的对象值为空`);
}
});
});
```
在这个例子中,我们使用了数组的 `forEach` 方法来对二维数组进行遍历。在外层的 `forEach` 中,第一个参数 `row` 表示当前行的数组,第二个参数 `i` 表示当前行的索引。在内层的 `forEach` 中,第一个参数 `obj` 表示当前对象,第二个参数 `j` 表示当前对象的索引。这样就可以对二维数组中的所有对象进行校验了。
需要注意的是,这里的判断条件和上面的示例一样,即只要 `name` 或 `age` 中有一个为空,就会被判断为空值。如果需要更加精确的判断,可以根据具体情况进行修改。
相关问题
es6一维数组转二维数组
可以使用ES6中的`Array.from()`方法和`Array.slice()`方法将一维数组转换为二维数组。具体实现如下:
```javascript
const arr1 = [1, 2, 3, 4, 5, 6];
const row = 2;
const col = 3;
const arr2 = Array.from({ length: row }, (_, rowIndex) =>
arr1.slice(rowIndex * col, rowIndex * col + col)
);
console.log(arr2);
// Output: [[1, 2, 3], [4, 5, 6]]
```
其中,`Array.from()`方法可以将类数组对象或可迭代对象转换成一个新的数组实例。第一个参数是一个类数组对象或可迭代对象,第二个参数是一个映射函数,用于对每个元素进行处理。在这个例子中,第一个参数是一个包含两个元素的数组,长度为`row`,第二个参数是一个映射函数,它的第一个参数是元素的值,第二个参数是元素的索引。`arr1.slice(rowIndex * col, rowIndex * col + col)`用于取出一段长度为`col`的数组,从而将一维数组转换成二维数组。
es6 对对象数组遍历
ES6 提供了一种新的遍历对象数组的方法,即使用 for...of 循环。这种方法可以遍历数组中的每个元素,而不需要使用传统的 for 循环或 forEach() 方法。例如:
const arr = [1, 2, 3];
for (let item of arr) {
console.log(item);
}
// Output:
// 1
// 2
// 3
另外,ES6 还提供了一些新的数组方法,如 map()、filter()、reduce() 等,可以更方便地对数组进行操作。
阅读全文