小言_互联网的博客

手写实现call函数

514人阅读  评论(0)

在大厂的面试中,手写实现call,apply,bind(特别是bind)一直是比较高频的面试题,在这里我们先来实现一下call函数。

思路

  1. 根据call的规则设置上下文对象,也就是this的指向。
  2. 通过设置context的属性,将函数的this指向隐式绑定到context上
  3. 通过隐式绑定执行函数并传递参数。
  4. 删除临时属性,返回函数执行结果
Function.prototype.myCall = function (context, ...arr) {
    if (context === null || context === undefined) {
       // 指定为 null 和 undefined 的 this 值会自动指向全局对象(浏览器中为window)
        context = window 
    } else {
        context = Object(context) // 值为原始值(数字,字符串,布尔值)的 this 会指向该原始值的实例对象
    }
    const specialPrototype = Symbol('特殊属性Symbol') // 用于临时储存函数
    context[specialPrototype] = this; // 函数的this指向隐式绑定到context上
    let result = context[specialPrototype](...arr); // 通过隐式绑定执行函数并传递参数
    delete context[specialPrototype]; // 删除上下文对象的属性
    return result; // 返回函数执行结果
};

判断函数上下文对象,不能简单的以context是否为false来判断。如:

context = context ? Object(context) : window; 
context = context || window; 

当这样判断时,一些值(如' '、0、false)也会导致函数的上下文对象绑定到window上,而call会将函数的上下文对象会绑定到这些原始值的实例对象上(String、Boolean、Number)。


转载:https://blog.csdn.net/weixin_40161974/article/details/102398957
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场