Arrar.prototype.map()的用法

---恢复内容开始---

map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。

array.map(callback[, thisArg])

  注:[]在语法中[]内的内容表示可选参数

callback原数组中的元素经过该方法后返回一个新的元素。

currentValue

callback 的第一个参数,数组中当前被传递的元素。

index

callback 的第二个参数,数组中当前被传递的元素的索引。

array

callback 的第三个参数,调用 map 方法的数组。

thisArg执行 callback 函数时 this 指向的对象。

    如果 thisArg 参数有值,则每次 callback 函数被调用的时候,this 都会指向 thisArg 参数上的这个对象。如果省略了 thisArg 参数,或者赋值为 null 或 undefined,则 this 指向全局对象 。

map 不修改调用它的原数组本身(当然可以在 callback 执行时改变原数组)。

使用 map 方法处理数组时,数组元素的范围是在 callback 方法第一次调用之前就已经确定了。在 map 方法执行的过程中:原数组中新增加的元素将不会被 callback 访问到;若已经存在的元素被改变或删除了,则它们的传递到 callback 的值是 map 方法遍历到它们的那一时刻的值;而被删除的元素将不会被访问到。

  

  <script type='text/javascript'>
var arr = [1,8,5,3,2,8];
var arr1 = arr.map(function (value) {
arr.push(5);
return value*3;
})
console.log(arr1);
console.log(arr);
</script>
 这里是输出的值,可以看出,在执行函数的时候给数组添加的值,是不会被访问到的
[3, 24, 15, 9, 6, 24]
[1, 8, 5, 3, 2, 8, 5, 5, 5, 5, 5, 5]

---恢复内容结束---

上一篇:微软职位内部推荐-Data Scientist


下一篇:HTML5教程之本地存储SessionStorage