当前位置: 移动技术网 > IT编程>开发语言>JavaScript > (JavaScript基础向)日常小发现:forEach等函数的第二个参数的用法

(JavaScript基础向)日常小发现:forEach等函数的第二个参数的用法

2018年12月26日  | 移动技术网IT编程  | 我要评论

foreach函数用得平时用得比较多,但是从来没想到foreach函数还有第二个参数。

这里是菜鸟教程对foreach函数的详细说明:。

如上图,foreach函数有第二个参数 thisvalue。

简单点来说,就是我们可以直接使用第二个参数来指定函数里的this的值,而不需要使用箭头函数或者在外面定义var that = this;等操作。

测试代码:

 1 var obj = {
 2     name: "小明",
 3     say: function() {
 4         console.log(this.name);
 5     },
 6     think: function() {
 7         var arr = [1,2,3,4];
 8         arr.foreach(function(item) {
 9             console.log(this);
10         })
11         console.log('---------')
12         arr.foreach(function(item) {
13             console.log(this);
14         }, this)
15     }
16 }
17 
18 obj.say();
19 obj.think();

测试结果:

在加上第二个参数前,foreach函数里的this默认是指向window的,在加了第二个参数this之后则指向foreach函数所在的对象了。

不仅foreach函数是如此,some、map等函数都是如此,具体还有多少函数是如此还有待大家自己发现哈,只要留个心眼,在用到这些函数的时候就会想起了。

以上所有内容,毕竟这个发现是基础向的,只要知道有这回事,要理解并不难。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网