你可能不知道的 new.target
2024-10-05 04:06:43
new 是构造函数生成实例的命令, ES6为 new 命令引入了 new.target属性。这个属性用于确定构造函数是怎么调用的。
在构造函数中, 如果一个构造函数不是通过 new
操作符调用的, new.target
会返回 undefined。
使用场景
如果一个构造函数不通过 new 命令生成实例, 就报错提醒
es5中是这样做的:
function Shape(options) {
if (this instanceof Shape) {
this.options = options
} else {
// 要么手动给它创建一个实例并返回
// return new Shape(options)
// 要么提醒
throw new Error('Shape 构造函数必须使用 new 操作符')
}
}
es6中可以这样做:
function Shape(options) {
// if (new.target !== 'undefined') {} 必须要在 constructor中使用 new.target, 在这里判断会报错
constructor(options) {
if (new.target !== 'undefined') {
this.options = options
} else {
throw new Error('必须使用 new 操作符')
}
}
}
以上代码通过 new.target 属性判断返回的是不是undefined即可知道这个构造函数是不是通过 new 操作符调用
一个构造函数只能用于子类继承, 自身不能 new
new.target这个属性,当子类继承父类会返回子类的构造函数名称
class Parent {
constructor() {
console.log(new.target)
}
}
class Child extends Parent {
constructor() {
super()
}
}
// Child
以上代码 Child子类继承父类, 那么父类构造函数中的 new.target 是子类构造函数的名称。
规定构造函数只能用于继承
class Zoo {
constructor() {
if (new.target === Zoo) throw new Error('Zoo构造函数只能用于子类继承')
}
}
const zoo = new Zoo() // 报错
class Dog extends Zoo {
constructor() {
super()
}
}
const dog = new Dog() // 不报错
tip : new.target 在外部使用会报错
最新文章
- Java实现多线程断点下载(下载过程中可以暂停)
- 【转】fatal error C1900: “P1”(第“20081201”版)和“P2”(第“20080116”版)之间 Il 不匹配
- iframe无刷新跨域并获得返回值
- 【WPF】Dispatcher及线程操作
- locate,nl命令
- Linux对于录音
- stop总结
- [福大软工] W班 软工实践原型设计—成绩公布
- C Primer Plus 第7章 C控制语句:分支和跳转 编程练习
- 初窥css---选择器及相关特性
- Py 最全的常用正则表达式大全 ZZ
- bootstrap-fileinput多图片上传
- svg 动画 透明度 放大缩小 x轴Y轴
- DEVEXPRESS GRIDVIEW 代码添加按钮(转)
- 改变RadioButton的文字位置以及距离
- DSL 系列(1) - 扩展点的论述与实现
- Android 富文本编辑器实现方案
- opencv学习之路(4)、Mat类介绍,基本绘图函数
- hping安装过程
- Ubuntu+Nginx+uWSGI+Flask应用