JS手搓代码----(new)

引言,书接上回我们已经了解过了call.apply在函数调用当中的指向,但我们今天要使用这两个关键字来实现手搓JS代码中的关键字---new

一、New的用法与功能

在我们手搓操作符具体实现之前,需要回顾一下new操作符的具体做法:

new 操作符执行时,实际上完成了以下几个核心步骤:

  1. 创建一个全新的空对象
  2. 将这个新对象的原型 (__proto__) 指向构造函数的 prototype 属性
  3. 执行构造函数,并将 this 绑定到新创建的对象上
  4. 根据构造函数的返回值类型,决定最终返回的对象

二、手写实现New的方式

2.1构造手写new的函数

现在需要一步步手动手写实现New的方法,我们定义函数objectFactory来替代传统的new,实现手写new。这时候我们就要思考该函数的参数该如何定义了?

传统的参数往往是不确定的,我们在objectFactory中对参数的处理采用argments

定义objectFactory时不需要指定参数,在内部用argments来处理,这样子无论有多少个参数都能处理了

2.2创建一个新对象

这行代码创建了一个全新的空对象 obj,它将成为最终的实例对象。

js 复制代码
function objectFactory(){
  var obj = {};
}

2.3构造函数

这一步我们需要把参数中的第一项:构造函数给拿出来,因为等下我们针对构造函数可能要做一些操作,比如指定原型链。需要使用下列代码:

js 复制代码
  var Constructor = [].shift.call(arguments);

由于aruguments不支持直接使用shift方法,所以我们需要借助别的方式来让arguments来使用shift方法,该行代码通过数组shift方法从arguments中提取第一个参数作为构造函数,通常用于模拟new关键字创建实例。

所以此时就可以达到我们想要的效果:删除arguments中的第一项,并且将其返回,此时Constructor就是Person构造函数,而arguments现在只剩下除了Person以外的参数(比如'name'、'age')

2.4 原型链操作

接下来,我们来实现将obj__proto__设置为构造函数的prototype

2.5 更改this指向

Constructor里的this指向变成我们的最终返回的对象obj。这里即可以使用call,也可以使用apply,在这里使用apply是因为arguments去除第一个元素剩下的都是其参数。

三、处理返回对象

判断构造函数返回值是否为对象,如果为对象就使用构造函数返回的值,否则使用 obj,这样就实现了忽略构造函数返回的原始值。

如果构造函数有返回值,返回值且是对象的时候,使用返回值。使用||的写法,当return null时,也能很好地处理了。

四、结语

本文手动实现了 new 操作符核心逻辑:通过创建空对象、挂载原型链、执行构造函数、处理返回值四步,完美模拟对象实例化过程。重点解析原型链指向、构造函数上下文绑定及显式返回对象的特殊处理,搭配 Person 类测试用例,直观展示 instanceof 验证结果,是理解 JS 面向对象底层机制的绝佳实践。

相关推荐
无巧不成书02181 小时前
Windows PowerShell执行策略详解:从npm报错到完美解决
前端·windows·npm·powershell执行策略·执行策略·npm.ps1·脚本报错
Z兽兽7 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang7 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda8 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06268 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~9 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle9 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界9 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser10 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码203511 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos