一、forEach定义一个函数, 数组的普通循环遍历, 并为每个数组元素执行一次传入的callback/** * @param {*} element 当前处理元素 * @param {number}..., 但是可以在callback里面对原数组进行修改 2、 改变长度: 虽然callback可以修改原数组, 但遍历的范围在第一次调用时就会确定, 即在callback中对数组长度进行操作, 不影响本次遍历范围..., 直接影响到了原数组; 虽然遍历范围不变, 仍为 4, 但因为数组长度减小了, 所以会按最新的数组顺序 [2,3,4] 进行遍历, 且无法遍历到之前最后一个索引 [3]const a = [1, 2,...虽然callback的对长度的修改不影响遍历范围, 但如果在执行过程中, callback修改遍历初已定范围内的元素值, 则后续的遍历值会发生变化在遍历中对数组已有值重新赋值, 可以看到访问内容已经改变...对于数组中未初始化的值, forEach会直接跳过, 但是不会改变遍历元素的索引值[1, , , 4].forEach((v, i, array) => { console.log(`index $