《你不知道的JavaScript-上》关于this

为什么要使用this

this可以让函数自动引用合适的上下文对象。

误解

2种常见的误解:指向自身它的作用域

1. 指向自身

想要记录一下函数foo被调用次数,以下是错误的代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
function foo(num){
console.log("foo:"+num);

//记录foo被调用的次数
this.count++;
}

foo.count=0;

var i;

for(i=0;i<10;i++){
if(i>5){
foo(i);
}
}

//foo:6
//foo:7
//foo:8
//foo:9

//foo被调用多少次?
console.log(foo.count); //0

以上代码证明this并不指向自己。

2. 它的作用域

this在任何情况下都不指向函数的词法作用域。JS内部,作用域确实和对象类似,可见的标识符都是它的属性。但是作用域“对象”无法通过JS代码访问,它存在于JS引擎内部。

1
2
3
4
5
6
7
8
9
10
function foo(){
var a=2;
this.bar();
}

function bar(){
console.log(this.a);
}

foo(); //ReferenceError:a is not defined

代码中this联通foo()bar()的词法作用域,但是不可能实现。

this到底是什么

this是在运行时绑定的,并不是编写时绑定,它的上下文取决于函数调用时的各种条件。this的绑定和函数声明的位置没有任何关系,只取决于函数的调用方式。

当一个函数被调用时,会创建一个活动记录(或称执行上下文,也称执行环境)。这个记录会包含函数在哪里被调用(调用栈)、函数的调用方式、传入的参数等信息。this是这个记录的一个属性,会在函数执行过程中用到。

小结

首先明白this既不是指向函数自身,也不是指向函数的词法作用域。

this实际上是在函数被调用时发生的绑定,它指向什么完全取决于函数在哪里被调用。

liborn wechat
欢迎您扫一扫上面的微信二维码,订阅我的公众号!