原生JS forEach和map遍历的区别以及兼容写法?

原生JS forEach和map遍历的区别以及兼容写法


德玛西亚99
浏览 945回答 2
2回答

动漫人物

共同点:1.都是循环遍历数组中的每一项。2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前项的索引index,原始数组input。3.匿名函数中的this都是指Window。4.只能遍历数组。1.forEach()没有返回值。arr[].forEach(function(value,index,array){//do something})参数:value数组中的当前项, index当前项的索引, array原始数组;数组中有几项,那么传递进去的匿名回调函数就需要执行几次;理论上这个方法是没有返回值的,仅仅是遍历数组中的每一项,不对原来数组进行修改;但是可以自己通过数组的索引来修改原来的数组;var ary = [12,23,24,42,1];var res = ary.forEach(function (item,index,input) {input[index] = item*10;})console.log(res);//--> undefined;console.log(ary);//--> 通过数组索引改变了原数组;2.map()有返回值,可以return 出来。arr[].map(function(value,index,array){//do somethingreturn XXX})参数:value数组中的当前项,index当前项的索引,array原始数组;区别:map的回调函数中支持return返回值;return的是啥,相当于把数组中的这一项变为啥(并不影响原来的数组,只是相当于把原数组克隆一份,把克隆的这一份的数组中的对应项改变了);var ary = [12,23,24,42,1];var res = ary.map(function (item,index,input) {return item*10;})console.log(res);//-->[120,230,240,420,10]; 原数组拷贝了一份,并进行了修改console.log(ary);//-->[12,23,24,42,1]; 原数组并未发生变化

暮色呼如

var ary = [12,23,24,42,1];var res = ary.forEach(function (item,index,input) {input[index] = item*10;})console.log(res);//-->undefined;console.log(ary);//-->会对原来的数组产生改变;
打开App,查看更多内容
随时随地看视频慕课网APP