forEach和map的区别,简单写了IE低版本的原形封装
今天有点'不务正业',旧的没有写完又开新的,没办法 -0- 今天遇到这个特感兴趣嘛
入正题了
forEach 和 map 的区别
参考:http://blog.csdn.net/boysky0015/article/details/72983766
作者;boysky0015
相同点:
.只能遍历数组
.都是循环遍历数组中的每一项和调用数组本身
.匿名函数中的this都是指向window
.ie6-8都不支持 不同点:
默认返回对象不同
map返回调用对象本身,forEach默认不返回
forEach
语法array.forEach(function(currentValue, index, arr), thisValue)
这里的 thisValue 是什么鬼,求大神告知
//按菜鸟教程说
//可选。传递给函数的值一般用 "this" 值。
//如果这个参数为空, "undefined" 会传递给 "this" 值 //按这么说 undefined 会传给this(window)
//测试了 windowd 对象里面也没有
var arr = [,,,,];
arr.forEach(function(currentValue,index,arr){
console.log(currentValue + '---' + index + '---' + arr);
//1---0---1,2,3,4,5
//2---1---1,2,3,4,5
//3---2---1,2,3,4,5
//4---3---1,2,3,4,5
//5---4---1,2,3,4,5
});
console.log(arr); //原数组对象值不变
for(key in window){
key.indexOf('un')>-?console.log(key):false;
}; //传参也不执行
var arr = [,,,,],newArr = [];
arr.forEach(function(currentValue,index,arr){ },function(){alert()}); //不执行
map
语法array.map(function(currentValue,index,arr), thisValue)
这里的 thisValue 是什么鬼,求大神告知
//这就很奇怪了,怎么效果都是1样的
var arr = [,,,,];
arr.map(function(currentValue,index,arr){
console.log(currentValue + '---' + index + '---' + arr);
//1---0---1,2,3,4,5
//2---1---1,2,3,4,5
//3---2---1,2,3,4,5
//4---3---1,2,3,4,5
//5---4---1,2,3,4,5
});
console.log(arr); //原数组对象值不变
forEach 和 map 的区别
var arr = [,,,,];
var newArr = arr.forEach(function(currentValue,index,arr){
return currentValue += ;
});
console.log(arr); //[1, 2, 3, 4, 5]
console.log(newArr); //undefined var arr = [,,,,];
var newArr = arr.map(function(currentValue,index,arr){
return currentValue += ;
});
console.log(arr); //[1, 2, 3, 4, 5]
console.log(newArr); //[3, 4, 5, 6, 7] //forEach reurn的方法
var arr = [,,,,],newArr =[];
arr.forEach(function(currentValue,index,arr){
return newArr.push(currentValue += );
});
console.log(arr); //[1, 2, 3, 4, 5]
console.log(newArr); //undefined //map 有的时候还是挺方便的
var arr = [,,];
var newArr = arr.map(Math.sqrt);
console.log(newArr) //[1, 2, 3]
IE 6-8 封装原形上添加
//forEach
var arr = [,,,,];
Array.prototype.add_forEach = function add_forEach(val,i){
for(var i=;i<this.length;i++){
val.call(window,this[i],i,this);
}
};
arr.add_forEach(function(val,i,thisArr){
console.log(val + '--' + i + '--' + thisArr)
});
//map
var arr = [,,,,];
Array.prototype.add_map = function add_map(val,i,thisArr){
var newAry = [];
for(var i=;i<this.length;i++){
if(typeof val === 'function') {
val.call(window,this[i],i,this);
newAry[newAry.length] = val;
}
};
return newAry;
};
arr.add_map(function(val,i,thisArr){
console.log(val + '--' + i + '--' + thisArr + this);
})
forEach和map的区别,简单写了IE低版本的原形封装的更多相关文章
- 数组遍历方法forEach 和 map 的区别
数组遍历方法forEach 和 map 的区别:https://www.cnblogs.com/sticktong/p/7602783.html
- js中的forEach和map的区别
我们先来看两者之间的相同之处 var arr = ['a','b','c','d']; arr.forEach(function(item,index,arr){ //item表示数组中的每一项,in ...
- 数组中的forEach和map的区别
大多数情况下,我们都要对数组进行遍历,然后经常用到的两个方法就是forEach和map方法. 先来说说它们的共同点 相同点 都是循环遍历数组中的每一项 forEach和map方法里每次执行匿名函数都支 ...
- JS中forEach和map的区别
共同点: 1.都是循环遍历数组中的每一项. 2.forEach()和map()里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前项的索引index,原始数组input. 3.匿名函数中 ...
- forEach和map的区别
写法上没什么区别,只是返回值会不一样,map能够返回每一项,而forEach则返回undefined,以后要用哪个你知道了吧?map返回新的数组,可以进行后续更多的操作,例如: let arr = [ ...
- forEach和map和for方法的区别
JS中的forEach.$.each.map方法推荐 转载 2016-04-05 投稿:jingxian 我要评论 下面小编就为大家带来一篇JS中的forEach.$.each.map方法 ...
- forEach和map的用法和区别
forEach()和map()都是处理数组的高阶函数有相同的三个值:(currentValue,index,arr): currentValue:必选,当前元素的值,index:可选,当前元素的下标, ...
- JS的forEach和map方法的区别,还有一个$.each
forEach()和map()两个方法都是ECMA5中Array引进的新方法,主要作用是对数组的每个元素执行一次提供的函数,但是它们之间还是有区别的.jQuery也有一个方法$.each(),长得和f ...
- 原生JS forEach()和map()遍历的区别以及兼容写法
一.原生JS forEach()和map()遍历 共同点: 1.都是循环遍历数组中的每一项. 2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前 ...
随机推荐
- 转:JDK1.8-Stream()使用详解
为什么需要 Stream Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念.它也不同于 StAX 对 ...
- plsql判断和循环
if语句 语法1 如果条件成立,执行if和end if 之间的语句. if 条件表达式 then plsql语句; end if; 语法2 if 条件表达式 then 条件成立时执行的语句; else ...
- C#语言和SQL Server数据库技术_前四章错题
1.在C#中,如果让某个方法只能被它所在的程序集内的其他方法访问,可使用(C)修饰这个方法. (选择一项) A:private B:protected C:internal D:以上都不对 2.下 ...
- Java中替换字符串中特定字符,replaceAll,replace,replaceFirst的区别
使用“;”替换过字符串中的“,” public class Test01 {public static void main(String[] args) {String number = " ...
- P4072 [SDOI2016](BZOJ4518) 征途 [斜率优化DP]
题目描述 Pine开始了从S地到T地的征途. 从S地到T地的路可以划分成n段,相邻两段路的分界点设有休息站. Pine计划用m天到达T地.除第m天外,每一天晚上Pine都必须在休息站过夜.所以,一段路 ...
- CF 1131A,1131B,1131C,1131D,1131F(Round541 A,B,C,D,F)题解
A. Sea Battle time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- HYSBZ 1036树链剖分
一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u v: 询问从 ...
- rsync服务的讲解
第2章 rsync备份服务器的搭建 2.1 rsync备份服务器的概念 2.1.1 概念 rsync服务器对网站服务器数据进行备份(防止数据丢失和数据进行恢复) rsync服务器对网站服务器数据进行对 ...
- 学Maven,这篇万余字的教程,真的够用了!
1 Maven 介绍 1.1 为什么使用 Maven 由于 Java 的生态非常丰富,无论你想实现什么功能,都能找到对应的工具类,这些工具类都是以 jar 包的形式出现的,例如 Spring,Spri ...
- centos7 7.3php编译安装
1.首先更新依赖包. yum -y update 2.安装依赖包 yum -y install libxml2 libxml2-devel openssl openssl-devel bzip2 bz ...