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函数
标题来源:https://www.cdcxhl.com/article36/ppjgpg.html

成都网站建设公司_创新互联,为您提供网站维护软件开发虚拟主机全网营销推广微信公众号品牌网站制作

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都做网站