new操作符创建新对象,将其原型指向构造函数的prototype,并将构造函数的this绑定到该对象;接着执行构造函数代码,若返回非原始类型值则替代新对象,否则返回新对象。

当你在JavaScript中使用 new 操作符调用一个构造函数时,JavaScript引擎会自动执行一系列步骤来创建并初始化一个新的对象。这个过程虽然看起来简单,但背后涉及多个关键操作。
new 操作符首先会创建一个全新的、干净的空对象。这个对象的原型会被设置为构造函数的 prototype 属性。也就是说,新对象会继承构造函数 prototype 上的所有属性和方法。
JavaScript 会将构造函数内部的 this 指向刚刚创建的新对象。这意味着在构造函数中对 this 所做的任何修改(比如添加属性或方法),都会直接作用在这个新对象上。
例如:
立即学习“Java免费学习笔记(深入)”;
function Person(name) {构造函数体内的代码会被执行。通常这包括给 this 添加属性或方法。如果构造函数返回了一个非原始类型的值(即对象、数组、函数等),那么这个返回值会取代 new 创建的对象。
注意:如果构造函数返回的是原始值(如字符串、数字),则该返回值会被忽略,仍然返回新创建的对象。
默认情况下,new 操作符会返回刚创建并绑定 this 的新对象。但如果构造函数中 return 了一个对象类型值,那么这个返回值将成为 new 表达式的结果。
示例:
function Foo() {基本上就这些。new 操作符的本质就是自动化地完成对象创建、this 绑定、属性初始化和返回实例的过程。理解它有助于掌握 JavaScript 的面向对象机制和原型链基础。不复杂但容易忽略细节。
以上就是JavaScript中的new操作符背后发生了什么?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号