❗ 函数内部中的 this 指向谁,不是在函数定义时决定的,而是在函数第一次调用并执行的时候决定的
1. call 方法
语法:函数名.call(调用者, 参数1, …)
作用:函数被借用时,会立即执行,并且函数体内的this会指向借用者或调用者
function fn(name, age) {
this.name = name;
this.age = age;
}
const obj = {}
// 经过call,this指向obj,obj开始有name、age属性
fn.call(obj, '李四', 100)
// 以下this均指向window,name:undefined,age:undefined
fn.call()
fn.call(null)
fn.call(undefined)
结果:普通函数的this指向window,利用call方法将this指向了obj
2. apply方法
语法:函数名.apply(调用者, [参数, …])
作用:函数被借用时,会立即执行,并且函数体内的this会指向借用者或调用者
function fn(name, age) {
this.name = name;
this.age = age;
}
const obj = {}
// 经过apply,this指向obj,obj开始有name、age属性
fn.apply(obj, ['李四', 100])
// 以下this均指向window,name:undefined,age:undefined
fn.apply()
fn.apply(null)
fn.apply(undefined)
结果:普通函数的this指向window,利用apply方法将this指向了obj
3. bind方法
语法:函数名.bind(调用者, 参数, …)
作用:函数被借用时,不会立即执行,而是返回一个新的函数。需要自己手动调用新的函数来改变this指向
function fn(name, age) {
this.name = name;
this.age = age;
}
const obj = {}
// const newFn = fn.bind(obj, '李四', 100)
// newFn()
fn.bind(obj, '李四', 100)()
结果:普通函数的this指向window,利用bind方法将this指向了obj文章来源:https://www.toymoban.com/news/detail-834115.html
💤总结:
相同点: 三者都可以把一个函数应用到其他对象身上,注意不是自身对象
不同点:
○ call,apply是直接执行函数调用。bind是绑定,执行需要再次调用。
○ call,bind接收逗号分隔的无限个参数列表;apply接收数组作为参数。文章来源地址https://www.toymoban.com/news/detail-834115.html
到了这里,关于web前端开发this指向问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!