信息发布→ 登录 注册 退出

J*aScript new操作符做了什么_它如何创建实例?

发布时间:2025-12-15

点击量:
new操作符执行四步:1.创建空对象;2.绑定原型到构造函数prototype;3.以该对象为this执行构造函数,若返回对象则用其替换实例,否则返回实例;4.返回最终对象。

javascript new操作符做了什么_它如何创建实例?

new 操作符不是简单地“分配内存”或“调用构造函数”,而是一套有明确顺序的四步操作:它先创建空对象,再绑定原型,接着执行构造函数,最后决定返回值。

1. 创建一个空的普通对象

J*aScript 引擎内部会调用 Object.create(null) 或等效机制,生成一个不带任何自有属性的空对象。这个对象的 __proto__(即内部 [[Prototype]])暂未设置,等待下一步绑定。

2. 将新对象的原型指向构造函数的 prototype

引擎把上一步创建的对象的 [[Prototype]] 链接到构造函数的 prototype 属性上。这意味着后续通过 instance.method() 调用的方法,能顺着原型链找到构造函数 prototype 上定义的函数。

例如:

星声AI 星声AI

可分享的AI播客内容生成器和效率工具

星声AI 185 查看详情 星声AI
function Person(name) { this.name = name; }
Person.prototype.sayHi = function() { return 'Hi ' + this.name; };
const p = new Person('Alice');
// p.__proto__ === Person.prototype → true
// p.sayHi() 正确执行,因为 sayHi 在原型上

3. 以新对象为 this,执行构造函数

构造函数被调用,且 this 绑定到刚创建的那个空对象。所有对 this.xxx = yyy 的赋值,都变成向该实例添加自有属性。

  • 如果构造函数显式返回一个**对象类型**(包括数组、函数、正则等),new 表达式最终就返回那个对象;
  • 如果返回原始值(string/number/boolean/null/undefined)或没写 return,new 就自动返回第一步创建的那个实例对象。

4. 返回最终对象(通常就是实例本身)

这一步看似简单,但决定了你能不能“覆盖”实例。比如:

function BadConstructor() {
  this.value = 42;
  return { custom: true }; // ✅ 返回对象 → new BadConstructor() 得到 { custom: true }
}
function GoodConstructor() {
  this.value = 42;
  return 'oops'; // ❌ 返回字符串 → 被忽略,仍返回实例
}

基本上就这些。理解这四步,就能明白为什么 new 不可替代——它同时处理了原型继承、this 绑定和返回逻辑,缺一不可。

以上就是J*aScript new操作符做了什么_它如何创建实例?的详细内容,更多请关注其它相关文章!


相关文章: poki免费入口快捷访问 poki人气小游戏直接玩站点  谷歌浏览器浏览体验优化_谷歌浏览器新版直连永久可用提示  2025年云电脑操作系统体验 | 无需本地硬件,随时随地使用高性能PC  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  J*a如何实现并发下载文件_J*a多线程IO性能优化案例  漫蛙manwa官网登录界面_漫蛙漫画网页版主站入口  TikTok评论显示延迟如何处理 TikTok评论刷新优化方法  AO3最新官网入口公告_2025AO3镜像站实时查询方法  电脑IP地址怎么查 查看本机IP地址的几种方法  如何在PHP中实现基于MySQL的动态分页查询  Golang如何使用net/url解析URL_Golang URL解析与处理方法  荒野行动PC版怎么注册_荒野行动PC版账号注册详细流程图文教程  漫蛙Manwa2官网入口地址分享 漫蛙漫画PC版永久访问通道  在python-socketio事件处理器中安全访问Flask应用上下文  魅族20怎样在浏览器开无图省流_iPhone魅族20浏览器开无图省流【流量节省】  c++如何实现一个简单的ECS框架_c++数据驱动设计与游戏开发  Excel组合图表怎么做 Excel创建柱状图与折线组合图教程【图表】  如何在Promise链中优雅地中断后续then执行  小红书网页版入口链接分享 小红书官网直接进  树莓派传感器触发:通过Twilio API发送WhatsApp消息教程  优化大型XML文件解析:基于Python流式处理的内存高效方案  C++如何连接MySQL数据库_C++使用Connector/C++操作MySQL数据库教程  Angular中父组件异步更新子组件复选框状态的实践指南  使用 Pandas 高效处理 .dat 文件:数据清洗与数值计算实战  Win11输入法不见了怎么办_Windows11恢复语言栏显示方法  如何使用纯J*aScript判断Input元素是否在特定类容器内  蛙漫移动版在线看 蛙漫手机浏览器直达入口  LINUX的perf命令入门_LINUX官方性能分析工具的使用与解读  C++ vector二维数组定义_C++ vector of vector用法  PDF文件体积过大处理_PDF压缩技巧详解  126邮箱手机版登录官网2026_126手机邮箱免费入口最新  实现分段式页面滚动导航:CSS与J*aScript教程  三星GalaxyZFold5怎样在相册制作折叠屏分镜_iPhone三星GalaxyZFold5相册制作折叠屏分镜【创意编辑】  神经网络二分类模型训练异常:高损失与完美验证准确率的排查与修正  Promise错误处理:在catch后终止链式then执行的策略  微博网页版主页入口 微博官方网站免登录访问  Google翻译怎么语音输入_Google翻译语音输入功能使用与设置方法  微信网页版官方入口直达 微信网页版网页版登录使用方法  QQ邮箱正确登录入口_QQ邮箱官方网站使用地址  KFC游戏互动怎么赢取优惠券_KFC线上游戏活动参与与优惠代码赢取教程  Yandex搜索引擎一键访问入口_俄罗斯Yandex官网免登录  正确连接J*aScript到HTML实现可点击图片与自定义事件处理  Win10怎么制作U盘启动盘 Win10系统安装U盘制作教程【详解】  谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问  Node.js中HTML按钮与J*aScript函数交互的正确姿势  J*a应用程序首次运行自动创建文件与目录的最佳实践  css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异  谷歌google账号注册详细步骤 谷歌账号注册官方教程  mc.js官网登录入口 mc.js官方登录入口最新版  qq邮箱日历功能怎么用_创建日程与会议邀请的技巧 

在线客服
服务热线

服务热线

4008988990

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!