当前位置:   article > 正文

JavaScript -- forEach不改变原数组但是改变对象属性的问题_foreach 中修改对象

foreach 中修改对象

我们一直知道forEach是没有返回值并且不直接改变原数组的,今天发现是不直接改变,实际上里面是包含着改变的。

1. forEach(item, index, arr),三个参数,如果直接用item=xxx是无法改变原数组的,但是如果用arr[index]就可以改变原数组。

  1. var s = [1,2,3,4];
  2. s.forEach(item=>{
  3. item = 'a'
  4. });
  5. console.log(s);// ["1", "2", "3", "4"] 未改变原数组
  6. s.forEach((item, index, arr)=>{
  7. arr[index] = 'b'
  8. });
  9. console.log(s);// ["b", "b", "b", "b"] 改变了原数组

2. 数组里面的子元素是对象,那么是可以改变对应属性的

  1. var s = [{a:1}, {a:1}];
  2. s.forEach(item=>{
  3. item = null;
  4. });
  5. console.log(s);//[{a: 1} ,{a: 1}] 未改变原数组
  6. s.forEach(item=>{
  7. item.a = 666;
  8. });
  9. console.log(s); // [{a: 666}, {a: 666}] //改变的原数组里面的对象属性

 

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号