Javascript之call方法的使用和实现

Javascript之call方法的使用和实现

面试的时候经常会遇到手写bind,apply,call方法的笔试题,今天我们就来看看call方法是什么并实现一下call方法,以免面试的时候回答不上来。

首先了解一下call方法是什么,实现了什么功能。

看看MDN上的介绍

Function.prototype.call()
**call()** 方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数。

示例:

var hello = function (a, b, c, d) {
      console.log(this.name);
      console.log(a, b, c, d)
    };

    var demo = {
      name: 'demo'
    };

var h = hello.call(demo, 1, 2, 3, 4);
// demo
// 1 2 3 4
    

可以看到啊,call方法中的this指向是传进来的第一个对象,传进来的其他参数,依次传到原函数中,最后把结果输出就行了,下面我们来简单实现下。

Function.prototype.myCall = function () {
      const obj = arguments[0]
      obj.tempFunction = this
      const params = []
      for (let i = 1; i < arguments.length; i++) {
        params.push(arguments[i])

      }
      const res = obj.tempFunction(...params)
      delete obj.tempFunction
      return res
}

call方法的实现就要用到arguments了,不然那么多参数从不能都用形参吧哈哈。当然上面还有很多很多要优化的地方,比如说参数的校验,params的定义占据了额外的内存空间,解构的方法不兼容老的浏览器,但是总的来说思路是这样的,优化的事情,就交给各位看官吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值