箭头函数的内部石没有this指向的,箭头函数的this指向是由外层函数的作用域来决定的。
var test=()=>{
console.log(this);
}
test();
默认绑定规则--独立调用对箭头函数无效
var a=0;
function foo(){
console.log(this);
var test=()=>{
console.log(this);
}
return test;
}
var obj1={
a:1,
foo:foo
}
var obj2={
a:1,
foo:foo
}
obj1.foo()();//独立调用,按道理是指向window的,但是是箭头函数,无法改变箭头函数的this指向
显示绑定规则对箭头函数无效
//一般函数此时的this指向为obj2;
var bar=foo().call(obj2);//window
隐私绑定规则对箭头函数无效
var obj3={
a:1,
foo:()=>{
console.log(this);
}
}
obj3.foo();//隐式绑定
箭头函数是不允许作为构造函数来使用的,new不能实例化箭头函数,如果用作构造函数来使用就会报错。
var foo=()=>{
console.log(this);
}
foo();//window
new foo();
只要是箭头函数,适用于普通函数的所有绑定规则对于箭头函数都不适用。箭头函数的this指向取决于父环境中的this指向(即箭头函数不存在this指向)
如果箭头函数在全局当中,那么this指向一定是window。