JS中的new运算符有何用,怎么手动模拟实现new
Admin 2022-06-18 群英技术资讯 1196 次浏览
这篇文章主要介绍“JS中的new运算符有何用,怎么手动模拟实现new”,有一些人在JS中的new运算符有何用,怎么手动模拟实现new的问题上存在疑惑,接下来小编就给大家来介绍一下相关的内容,希望对大家解答有帮助,有这个方面学习需要的朋友就继续往下看吧。MDN文档:new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。
class Person {
constructor(name) {
this.name = name;
}
}
// 创建自定义对象类型的实例
const person = new Person('小明')
// 创建具有构造函数的内置对象的实例
const date = new Date()
new的作用:创建对象的实例
上面说了new的作用是创建对象的实例,那么它究竟是怎么创建实例的,内部干了哪几件事?
以new Person()为例,当它执行时,会发生以下事情:
创建一个空的简单JS对象
const obj = {}
给这个对象添加属性__proto__,并将该属性链接到构造函数的原型对象
obj.__proto__ = Person.prototype
调用构造函数Person,并将this绑定到新创建的对象obj
Person.apply(obj)
如果构造函数没有显式返回一个对象,则返回新创建的对象,即obj
如上所述,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步,一步一步写就可以了
ES5提供了Object.create方法,该方法可以创建一个对象,并让新对象的__proto__属性指向已经存在的对象。
所以我们可以使用这个方法合并1、2两步
const obj = Object.create(constructor.prototype)
// 等价于
const obj = {}
obj.__proto__ = constructor.prototype
对于第4步,再解释一下
return(通常情况)那么person就是新创建的对象objperson还是新创建的对象objfunction 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来创建
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
之前小编给大家介绍过JS宏任务与微任务的操作,今天我们继续来了解宏任务与微任务的内容,下文主要给大家讲一讲JavaScript宏任务与微任务的执行顺序,感兴趣的朋友就继续往下看吧。
这篇文章给大家分享的是JavaScript中位运算符。小编觉得挺实用的,因此分享给大家做个参考。JavaScript中的有7种位运算符,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来我们一起来看看它们的使用。
众所周知javascript语言中只提供了几种基本类型的数据类型,而二叉树是一种数据结构,在一些查询等操作中能提供较好的性能,这篇文章主要给大家介绍了关于利用JS实现二叉树遍历算法的相关资料,需要的朋友可以参考下
这篇文章主要为大家详细介绍了微信小程序实现多列选择器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
在 JavaScript 中,不像 Java 等语言,它没有任何打印或者输出方法的,通常使用如下 4 种方式来输出数据。。下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008