this指向问题
script标签中的this指向window
全局变量和全局方法前面都省了一个window。
<script>
console.log(this);
</script>
函数中的this
- 普通函数中的this指向window
- 函数中的this,要看执行时候的上下文环境,谁调用函数,this就指向谁
setInterval中的this指向的是window
setInterval是window全局对象的一个方法
箭头函数指向的是函数上一层作用域中的this
类中的this指向的是他的实例
apply与call中的this
- call中的this指向call的第一个参数,执行say函数,函数中的this用{name:“jjj”}冒充,参数是3,5
- apply中的this指向apply的第一个参数,执行say()函数,函数中的this用{name:“Fiona”}冒充,参数以数组形式传入[7,6].
function say(a,b){
console.log(this,a+b);
}
say(5,2);//普通函数调用,指向window
say.call({name:"jjj",age:18},3,5);
say.apply({name:"Fiona"},[7,6]);
bind方法
- 用bind创建的函数this指向的是bind的第一个参数(改变函数this指向)
var sa = say.bind({name:"jdfhj",10,14);
sa();//this指向为{naem:"jdfhj"}