新闻中心

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操作符做了什么_它如何创建实例?的详细内容,更多请关注其它相关文章!


# 就能  # 云南网站建设及优化研究  # 宝坻seo排名公司  # 杭州建德营销推广  # 网站优化如何评价  # 广州seo网站推广技巧  # 工作室网站建设框架图  # seo本质是违法吗  # 长乐区企业seo推广  # seo项目怎么写  # seo一定要备案吗  # 相关文章  # 你能  # javascript  # 能做什么  # 内存管理  # 如何实现  # 如何用  # 如何使用  # 用它  # 绑定  # 为什么  # yy  # new操作符  # go  # java 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 如何在Promise链中优雅地中断后续then执行  cad怎么合并重叠的线段_cad清理重复重叠线条的操作方法  J*aScript map 迭代中检测空数组元素的有效方法  CSS Flexbox与媒体查询:实现响应式布局中元素的并排与堆叠  Golang如何实现Web接口签名验证_Golang Web接口签名校验开发方法  C++ typeid如何获取类型信息_C++ RTTI运行时类型识别用法  海棠账号登录入口_登录海棠账户同步阅读记录  荣耀Play7T运行卡顿解决_荣耀Play7T性能优化  Win10文件资源管理器“此电脑”分组怎么关 Win10恢复经典视图【技巧】  Django表单提交验证失败后保持字段值不刷新  Golang如何优雅处理error_Golang error处理最佳实践总结  Sublime怎么配置Nim语言环境_Sublime Nim代码高亮与补全  Win11怎么设置鼠标指针速度_Win11提高鼠标指针精确度选项  MAC怎么让Dock栏只显示当前运行的应用_MAC终端命令实现极简Dock栏  Go语言中对Map值调用带指针接收者方法:原理与最佳实践  手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析  外媒分析《GTA6》定价:卖100美元可以但真没必要!  2026春节假期时间安排 2026春节假日查询  Angular中父组件异步更新子组件复选框状态的实践指南  Mac怎么锁定备忘录_Mac备忘录加密设置教程  夸克浏览器网页版最新地址 夸克浏览器官方入口合集  为什么我的微信朋友圈看不到别人的更新_微信朋友圈更新显示异常解决方法  解决 MongoDB 聚合查询中对象数组 _id 匹配问题  抖音极速版最新版本 抖音极速版官方下载地址  TikTok国际版官网直达_TikTok国际版官网直达进入在线观看  Odoo 16:在表单视图中基于当前记录动态修改Tree视图属性  在WordPress中通过REST API获取BasicAuth保护的远程文章  押井守高度称赞《辐射4》:玩了八年都停不下来!  微信群消息显示延迟如何解决 微信群消息刷新优化方法  PDF文件体积过大处理_PDF压缩技巧详解  React列表渲染与独立状态管理:避免全局状态影响局部更新  Kafka Streams中基于消息头条件过滤消息的实现指南  CSS实现侧边栏导航项全宽圆角悬停背景效果  css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容  MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复  微信网页版登录教程_微信网页版登录入口在哪  在J*a中如何隐藏复杂性_使用门面模式组织对象交互  虚幻5科幻题材ARPG大作遭取消!本是《奇异人生》厂商新作  AngularJS $http POST请求数据传递与Go后端接收实践  处理Kafka消费者会话超时:深入理解消息处理语义与幂等性  Node.js CSV 数据处理:基于字段空值条件过滤整条记录的策略  php源码怎么看淘宝客系统_看php源码淘宝客系统技巧  微信网页版官方快速登录入口 微信网页版网页版账号直达  荒野行动PC版怎么注册_荒野行动PC版账号注册详细流程图文教程  Windows10怎么开启存储感知 Windows10系统设置自动清理临时文件释放C盘空间【教程】  在J*aScript中复现SciPy的B样条拟合与求值:关键考量  探索高级语言到C/C++的转译路径:以Go为例及内存管理策略  微信网页版官方入口直达 微信网页版网页版登录使用方法  漫蛙漫画官方首页 漫蛙2漫画在线阅读入口  小米14应用无法联网原因分析_小米14网络权限修复 

搜索