加入收藏 | 设为首页 | 会员中心 | 我要投稿 濮阳站长网 (https://www.0393zz.cn/)- 专属主机、数据湖、操作系统、媒体智能、数据分析!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

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 是所有引用类型值的基类型。

(编辑:濮阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读