Skip to content

实现call

面试中所遇频率极高的手写题之一

call简介

  • 改变this指向,然后执行函数返回结果
  • 第一个参数为新的this,不设置则默认globalThis
  • 第二个及之后的参数作为其参数传入

使用

js
function print(a, b) {
    console.log(this.name, a + b);
}
print(1, 2) // undefined 3

print.call({ name: 'print' }, 6, 5) // print 11
function print(a, b) {
    console.log(this.name, a + b);
}
print(1, 2) // undefined 3

print.call({ name: 'print' }, 6, 5) // print 11

简单实现

不考虑各种边界情况

js
Function.prototype.mycall = function (thisArg) {
    thisArg = thisArg || window
    thisArg.fn = this
    const argvs = [...arguments].slice(1)
    const res = thisArg.fn(...argvs)
    delete thisArg.fn
    return res
}

function print(a, b) {
    console.log(this.name, a + b);
}
print(1, 2) // undefined 3

print.mycall({ name: 'print' }, 6, 5) // print 11
Function.prototype.mycall = function (thisArg) {
    thisArg = thisArg || window
    thisArg.fn = this
    const argvs = [...arguments].slice(1)
    const res = thisArg.fn(...argvs)
    delete thisArg.fn
    return res
}

function print(a, b) {
    console.log(this.name, a + b);
}
print(1, 2) // undefined 3

print.mycall({ name: 'print' }, 6, 5) // print 11

更新于: