百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

javascript中的call方法的另一种实现方式-更接近原方法

myzbx 2025-09-03 05:31 22 浏览

上集我们说到对应的我们自己实现的call方法还是有一点纰漏,这里我们就解决它

// 一、预备知识(简单介绍)
// 1、Function.prototype.call()
// 语法:function.call(thisArg, arg1, arg2, ...)
// 参数:thisArg可选的。在function函数运行时使用的this值。请注意,this可能不是该方法看到的实际值:如果这个函数处于非严格模式下,则指定为null或undefined时会自动替换为指向全局对象,原始值会被包装。arg1, arg2, ...指定的参数列表。
// 返回值:使用调用者提供的this值和参数调用该函数的返回值。若该方法没有返回值,则返回undefined

// 用法:
// call() 允许为不同的对象分配和调用属于一个对象的函数/方法。
// call() 提供新的 this 值给当前调用的函数/方法。你可以使用 call 来实现继承:写一个方法,然后让另外一个新的对象来继承它(而不是在新对象中再写一次这个方法)
// 2、this指针
// 在绝大多数情况下,函数的调用方式决定了this的值(运行时绑定)。this不能在执行期间被赋值,并且在每次函数被调用时this的值也可能会不同。ES5 引入了bind方法来设置函数的this值,而不用考虑函数如何被调用的。箭头函数不提供自身的 this 绑定(this的值将保持为闭合词法上下文的值)。当前执行上下文(global、function 或 eval)的一个属性,在非严格模式下,总是指向一个对象,在严格模式下可以是任意值。无论是否在严格模式下,在全局执行环境中(在任何函数体外部)this都指向全局对象。在函数内部,this的值取决于函数被调用的方式。在严格模式下,如果进入执行环境时没有设置this的值,this会保持为undefined 。可以使用globalThis获取全局对象,无论你的代码是否在当前上下文运行。

// 3、原型对象
// JavaScript 常被描述为一种基于原型的语言 (prototype-based language)——每个对象拥有一个原型对象,对象以其原型为模板、从原型继承方法和属性。原型对象也可能拥有原型,并从中继承方法和属性,一层一层、以此类推。这种关系常被称为原型链 (prototype chain),它解释了为何一个对象会拥有定义在其他对象中的属性和方法。这些属性和方法定义在 Object 的构造器函数 (constructor functions) 之上的prototype属性上,而非对象实例本身

// 4、Symbol
// symbol 是一种基本数据类型。Symbol() 函数会返回 symbol 类型的值,该类型具有静态属性和静态方法。它的静态属性会暴露几个内建的成员对象;它的静态方法会暴露全局的 symbol 注册,且类似于内建对象类,但作为构造函数来说它并不完整,因为它不支持语法:"new Symbol()"。每个从 Symbol() 返回的 symbol 值都是唯一的。一个 symbol 值能作为对象属性的标识符;这是该数据类型仅有的目的

// 5、Object.defineProperty()
// Object.defineProperty()方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象,第一个参数是对象,第二个是对象里面的属性,后面的第三个是参数配置,当对象对这个属性设置会触发里面的set方法,获取会触发get方法我们可以在其中做一些我们自己的操作,这两个方法是默认就有的,当然我们可以显式声明出来再加添自己的逻辑


Function.prototype._call = function(context, ...args) {
    //globalThis是全局对象,在浏览器中,全局对象是 Window
    //注意这里我们将传入的对象和参数分开了
    context = context === null || context === void 0 ? globalThis : Object(context);
    //使用Symbol的原因:防止与提供新的 this 值的属性重复
    //这里的symbol是为了防止属性冲突
    const targetFn = Symbol('onlyKey');
    //下面这个Object.defineProperty常用于爬虫的hook代码,以及对应的vue2的响应式原理【有兴趣可以去源码看看】,在ES6还出现了Proxy的方式来实现且功能更强大
    Object.defineProperty(context, targetFn, {
        // enumerable:为true时,该属性才能够出现在对象的枚举属性中。
      enumerable: false,
      value: this,
    });
    //这里是调用对象的方法【再对象中方法其实也是一种属性】那么就会走对应的上面的Object.defineProperty中的get方法【默认就有的,我们也可以自己定义】,它的value是this,那个this就是context因为我们给的对象就是context也就是我们调用传入的obj
    const result = context[targetFn](...args);
    return result;
  };

  function add(a, b) {
    // 测试函数
    console.log(this)
    // { name: 'Alex-jsonk' }
    // 注意这里和上一集的已经不一样了和call方法一样了
    return a + b
}
let obj = {
    name: "Alex-jsonk"
}

console.log(add._call(obj, 1, 2));

//3

以上就是另一种写法,如果你面试前端工程师的时候只要写出一种已经超过大部分人了,当然我们只是为了最求技术的进步,成为顶端的人,我们必须精益求精,深入底层,下集再见。

相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 "小贱贱"韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...