深入JavaScript: 手写call和apply

本文详细讲解了JavaScript中Function.prototype.call和apply的方法,如何通过它们改变this指向并处理不定参数。通过实例演示了如何在函数内部设置作用域和使用扩展运算符处理arguments对象。
摘要由CSDN通过智能技术生成

Function.property.call

函数功能:

  1. 改变this指向
  2. 接受不定向传参

思路:
1.如何改变this的指向
: 在指定作用域添加函数作为其属性: 使this优先指向该作用域

2.如何接受不定向传参
:es 6扩展远算符 + arguments类数组

let id = 10017;
let obj = {
  id: 10018;
}
function Id(psw) {
  console.log(this.id)
  console.log(psw)
}
Id.call(obj)// 10018
Function.property.Mycall=function(context){
  context.func = this;
  context.func()
  delete context.func()
}
Function.property.Mycall=function(context){
  let context = context || window;
  context.func = this;
  let args = [];
  for(let i=1,len=arguments.length,i<len,i++) {
    args.push(arguments[i]);
  }
  let result = context.func(...args);
  delete context.func();
  return result;
}
Function.prototype.Mycall = function(content = window) {
    content.func = this;
    let args = [...arguments].slice(1);
    let result = content.func(...args);
    delete content.func;
    return result;
}

apply

Function.prototype.apply2 = function(context = window) {
    context.fn = this
    let result;
    // 判断是否有第二个参数
    if(arguments[1]) {
        result = context.fn(...arguments[1])
    } else {
        result = context.fn()
    }
    delete context.fn
    return result
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值