更改this指向的call() 、 apply() 和 bind()
首先,函数内部中的 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(调用者, 参数, …)
作用:函数被借用时,不会立即执行,而是返回一个新的函数。需要自己手动执行,一般用于不需要立即执行的时候
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
总结:
- 相同:三者都可以把一个函数应用到其他对象身上,注意不是自身对象
- 不同:
○ call,apply是直接执行函数调用。bind是绑定,执行需要再次调用。
○ call,bind接收逗号分隔的无限个参数列表;apply接收数组作为参数。
本文来自博客园,作者:RHCHIK,转载请注明原文链接:https://www.cnblogs.com/suihung/p/16205224.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)