JavaScript中new操作符的原理是什么?
发布时间:2022-02-19 14:00:07 所属栏目:语言 来源:互联网
导读:JavaScript中new操作符的原理是什么?一些刚接触JavaScript的朋友对于new操作符可能不是很了解,其实new的过程实际上是创建一个新对象,下面小编就给大家来介绍一下,下文有实例供大家参考。 new的用处 new的作用是通过构造函数来创建一个实例对象,该实例与
|
JavaScript中new操作符的原理是什么?一些刚接触JavaScript的朋友对于new操作符可能不是很了解,其实new的过程实际上是创建一个新对象,下面小编就给大家来介绍一下,下文有实例供大家参考。 new的用处 new的作用是通过构造函数来创建一个实例对象,该实例与原型和构造函数之间的关系如下图所示: 先来总结一下 创建一个空对象 空对象的内部属性 __proto__ 赋值为构造函数的 prototype 属性 将构造函数的 this 指向空对象 执行构造函数内部代码 返回该新对象 详细说明 执行 new 操作时会依次经过以下步骤: 1、创建一个空对象 空对象是 Object 的实例,即 {} 。 let obj = {} 2、空对象的内部属性 __proto__ 赋值为构造函数的 prototype 属性 该操作是为了将空对象链接到正确的原型上去 function Foo(num) { this.number = num } obj.__proto__ = Foo.prototype 3、将构造函数的 this 指向空对象 即构造函数内部的 this 被赋值为空对象,以便后面正确执行构造函数。 Foo.call(obj, 1) 4、执行构造函数内部代码 即给空对象添加属性、方法。 5、返回该新对象 如果构造函数内部通过 return 语句返回了一个引用类型值,则 new 操作最终返回这个引用类型值;否则返回刚创建的新对象。 引用类型值:除基本类型值(数值、字符串、布尔值、null、undefined、Symbol 值)以外的所有值。 模拟 new 操作符 下面的 myNew 函数模拟了 new 操作符的行为 function myNew(func, ...args) { let obj = {} obj.__proto__ = func.prototype let res = func.apply(obj, args) return res instanceof Object ? res : obj } function Foo(num) { this.number = num } let foo1 = myNew(Foo, 1) console.log(foo1 instanceof Foo) // true console.log(foo1.number) // 1 let foo2 = new Foo(2) console.log(foo2 instanceof Foo) // true console.log(foo2.number) // 2 上面通过 instanceof 操作符来判断构造函数的返回值是否为 Object 的实例,即是否为引用类型值;这是因为所有引用类型值都是 Object 的实例,Object 是所有引用类型值的基类型。 (编辑:濮阳站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
