1.以函数的形式调用时,this的指向为window,比如sum(),fun()。相当于window.fun()
2.以方法的形式调用时,this指向调用方法的那个对象。
3.以构造函数的形式调用时,this指向实例对象。
4.以事件绑定函数的形式调用时,this指向绑定事件的对象。
5使用call和apply调用时,this指向指定的那个对象。
6.ES6中箭头函数会继承外层函数调用的this绑定。
call()
call()可以调用一个函数,比如fn.call(),在括号内加参数可以改变this的指向。
const obj = {
name:'zyx',
age:'21'
}
function fn1(){
console.log(this) //window
console.log(this.name) //undefind
}
fn1.call()
call改变this指向
const obj = {
name:'zyx',
age:'21'
}
function fn1(){
console.log(this) //{name: "zyx", age: "21"}
console.log(this.name) //zyx
}
fn1.call(obj)
通过call实现继承
function people(name,age){
this.name = name;
this.age = age;
}
function student(name,age){
//通过this把student函数的参数传给people
people.call(this,name,age)
}
const student1 = new student('zyx',21)
console.log(JSON.stringify(student1))```