JS手写call方法

call方法是JS function中内置的一个方法,主要的作用有两个:

  • 改变函数的this指向
  • 向函数中传递参数

使用方式如下:

javascript 复制代码
fn.call(obj, 100, 200)

实现代码示例:

javascript 复制代码
Function.prototype.myCall = function(ctx, ...args) {

  ctx = ctx === undefined || ctx === null ? globalThis : Object(ctx)
  // 定义一个符号,使其唯一
  const key = Symbol()

  // 这样定义,使符号不可枚举
  Object.defineProperty(ctx, key, {
    value: this,
    enumerable: false
  })
  const r = ctx[key](...args)

  // 运行完没用了,就可以删除掉
  delete ctx[key]

  return r
}

function method(a, b) {
  console.log(this, 'this')
  console.log(a, b, 'args')
}

const a = {
  a: 2
}

method.myCall(a, 2, 3)
// 输出结果:{ a: 2 } this
//          2 3 args


method.myCall(this, 2, 3)
// node 环境没有 this
// 输出结果:{} this
//          2 3 args

method.myCall(1, 2, 3)
// 输出结果:[Number: 1] this
//          2 3 args
相关推荐
gihigo1998几秒前
基于MATLAB实现图像缺陷检测、清晰度评估及自动对焦功能
开发语言·matlab
克喵的水银蛇2 分钟前
Flutter 通用网络图片封装实战:带占位 / 错误 / 缓存的 CachedImageWidget
开发语言·前端·javascript
kong@react4 分钟前
springbpoot项目,富文本,xss脚本攻击防护,jsoup
java·前端·spring boot·xss
资深web全栈开发5 分钟前
从零构建即时通讯系统:Go + Vue3 实战指南
开发语言·后端·golang·im 通许
涵涵(互关)6 分钟前
后端返回的id到前端接收时,id改变了
前端·状态模式
码上成长8 分钟前
从零实现:react&Ts--批量导入 & Excel 模版下载功能
javascript·react.js·excel
小杍随笔9 分钟前
【Zed 编辑器配置全攻略:自动保存、Prettier、终端字体与格式化设置一步到位】
开发语言·rust·编辑器
拾忆,想起10 分钟前
Dubbo灰度发布完全指南:从精准引流到全链路灰度
前端·微服务·架构·dubbo·safari
liudongyang12312 分钟前
EasyExcel使用模版填充的方式,导致单元格边框消失
前端·html
Predestination王瀞潞12 分钟前
Python3:Fifteenth 类型注解(Type Hints)
开发语言·python