JavaScript系列之apply方法原生实现

首先来了解apply的用法:

function fn(name){
  console.log(`${name} ${this.msg}`)
}

const obj = {
  msg: 'Hello World'
}

fn.apply(obj, ['Ksmith'])

// Ksmith Hello World

原生实现

Function.prototype.apply = function(context = window, args) {
  // 第二参数如果不是一个对象的话
  if (!(args instanceof Object)) {
    throw new TypeError('CreateListFromArrayLike called on non-object')
  }
  // 除了数组以外的对象,都为空,也就是无参数
  // 主要是为了跟原生表现一致
  if(!(args instanceof Array)) {
    args = []
  }
  // context如果没传是window
  // 但如果传了,但并非是对象,怎么办?比如:String,Boolean等,但不包含Array、Function等
  context = context instanceof Object ? context : {}
  // 在上下文中执行fn方法,保证执行环境是context
  context.fn = this
  const result = context.fn(...args)
  // 原生call是不会污染context的,所以这里要删除掉
  delete context.fn
  // 返回执行结果
  return result
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值