⚠ 预备知识:
1 new 运算符简介MDN文档:new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。 class Person { constructor(name) { this.name = name; }}// 创建自定义对象类型的实例const person = new Person('小明')// 创建具有构造函数的内置对象的实例const date = new Date() new的作用:创建对象的实例
2 new 究竟干了什么事上面说了new 的作用是创建对象的实例,那么它究竟是怎么创建实例的,内部干了哪几件事? 以new Person()为例,当它执行时,会发生以下事情: 创建一个空的简单JS对象
给这个对象添加属性__proto__, 并将该属性链接到构造函数的原型对象
obj.__proto__ = Person.prototype 调用构造函数Person ,并将this 绑定到新创建的对象obj
如果构造函数没有显式返回一个对象,则返回新创建的对象,即obj
3 模拟实现 new 运算符如上所述,new 运算符就干了这么4件事,下面我们就根据这4个步骤用函数来模拟实现new (面试手写代码) const _new = function(constructor, ...args) { const obj = {} obj.__proto__ = constructor.prototype const res = constructor.apply(obj, args) // 这一步在"补充"中会详细解释 return res instanceof Object ? res : obj} 代码非常简单,就是按照上面4步,一步一步写就可以了
4 补充ES5 提供了Object.create 方法,该方法可以创建一个对象,并让新对象的__proto__ 属性指向已经存在的对象。
所以我们可以使用这个方法合并1、2两步 const obj = Object.create(constructor.prototype)// 等价于const obj = {}obj.__proto__ = constructor.prototype 对于第4步,再解释一下 - 如果构造函数没有显式
return (通常情况)那么person 就是新创建的对象obj - 如果构造函数返回的不是一个对象,比如1、"abc" 那么
person 还是新创建的对象obj function Person() { ... return 1} 如果构造函数显式返回了一个对象,比如{} 、function() {} 那么person 就不是新创建的对象obj 了,而是显式return 的这个对象 function Person() { // 函数也是对象 return function() {}} 所以我们在_new函数最后一句代码是: return res instanceof Object ? res : obj 注意:模拟实现的函数_new传入的参数只能是构造函数,不能是类
class Animal { ...}_new(Animal)// 会报错:Class constructor Animal cannot be invoked without 'new'// 类只能通过new来创建 到此这篇关于手写实现JS中的new的文章就介绍到这了,更多相关JS中的new内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net! 下载地址: 用JS写一个发布订阅模式 JS数组去重详情 |