重学JS系列: new 操作符,和实现一个 new 操作符

  1. new 的特点
  2. 如果实现一个 new 操作符

一、new 运算符

new运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。new 关键字会进行如下的操作:

  • 创建一个空的 js 对象{}
  • 链接该对象(即设置该对象的构造函数)到另一个对象 ;
  • 将步骤1新创建的对象作为this的上下文 ;
  • 如果该函数没有返回对象,则返回this
function Car(make, model, year) {
  this.make = make;
  this.model = model;
  this.year = year;
}

var car1 = new Car('Eagle', 'Talon TSi', 1993);

console.log(car1.make);
// expected output: "Eagle"

二、手工实现一个 new 操作符

实现步骤

  1. 上面说了 new操作符会返回一个对象, 所以我们需要在创建一个 object
  2. 那么我们需要将构造函数的的原型 设置到另一个对象上
  3. 将创建的对象 作为this的上下文
  4. 有属性返回属性, 没有则返回 this
function  create(Con, ...args) {
    let obj = {};
    Object.setPrototypeOf(obj, Con.prototype)
    let result = Con.apply(obj, args)
    return result instanceof Object ? result : obj
}

上面的函数 第一个参数作为构造函数传入, 接下来的参数被构造函数使用
然后按上面的1、2、3、4步骤实现

  • 创建一个 空对象
  • 将 构造函数的原型 设置给 空对象。 等用于 obj.__proto__ = Con.prototype
  • 将 obj 绑定到构造函数上, 并且通过剩余参数传入
  • 最后 判断 返回值是否为对象, 如果为对象 则 返回使用构造函数的result, 否则就返回 obj
那我们来看看最后实现的效果吧
function Test(name, age) {
    this.name = name
    this.age = age
}

Test.prototype.intr = function () {
    console.log(`my name is ${this.name}, i'm ${this.age} years old`)
}

const me = create(Test, 'gavin', '21')
console.log(me.name)  //output: gavin
console.log(me.age)  //output: 21

me.intr()  // my name is gavin, i'm 21 years old``
参考
web docs: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/new
掘金 yck: https://juejin.im/post/5c7b963ae51d453eb173896e
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值