js如何实现call函数

这篇文章主要为大家展示了“js如何实现call函数”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“js如何实现call函数”这篇文章吧。

创新互联是一家专注于成都做网站、网站设计与策划设计,珠山网站建设哪家好?创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:珠山等地区。珠山做网站价格咨询:028-86922220

call 函数的实现步骤:

  • 1.判断调用对象是否为函数,即使我们是定义在函数的原型上的,但是可能出现使用 call 等方式调用的情况。

  • 2.判断传入上下文对象是否存在,如果不存在,则设置为 window 。

  • 3.处理传入的参数,截取第一个参数后的所有参数。

  • 4.将函数作为上下文对象的一个属性。

  • 5.使用上下文对象来调用这个方法,并保存返回结果。

  • 6.删除刚才新增的属性。

  • 7.返回结果。

// call函数实现Function.prototype.myCall = function(context) {
  // 判断调用对象
  if (typeof this !== "function") {
    console.error("type error");
  }

  // 获取参数
  let args = [...arguments].slice(1),
    result = null;

  // 判断 context 是否传入,如果未传入则设置为 window
  context = context || window;

  // 将调用函数设为对象的方法
  context.fn = this;

  // 调用函数
  result = context.fn(...args);

  // 将属性删除
  delete context.fn;

  return result;};

以上是“js如何实现call函数”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


当前题目:js如何实现call函数
文章源于:http://hbruida.cn/article/ppjgpg.html