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 在外部使用会报错

最新文章

  1. Java实现多线程断点下载(下载过程中可以暂停)
  2. 【转】fatal error C1900: “P1”(第“20081201”版)和“P2”(第“20080116”版)之间 Il 不匹配
  3. iframe无刷新跨域并获得返回值
  4. 【WPF】Dispatcher及线程操作
  5. locate,nl命令
  6. Linux对于录音
  7. stop总结
  8. [福大软工] W班 软工实践原型设计—成绩公布
  9. C Primer Plus 第7章 C控制语句:分支和跳转 编程练习
  10. 初窥css---选择器及相关特性
  11. Py 最全的常用正则表达式大全 ZZ
  12. bootstrap-fileinput多图片上传
  13. svg 动画 透明度 放大缩小 x轴Y轴
  14. DEVEXPRESS GRIDVIEW 代码添加按钮(转)
  15. 改变RadioButton的文字位置以及距离
  16. DSL 系列(1) - 扩展点的论述与实现
  17. Android 富文本编辑器实现方案
  18. opencv学习之路(4)、Mat类介绍,基本绘图函数
  19. hping安装过程
  20. Ubuntu+Nginx+uWSGI+Flask应用

热门文章

  1. 性能测试工具LoadRunner07-LR之Virtual User Generator 参数化设置
  2. [转]jQuery Mobile动态刷新页面样式
  3. 贪心:钱币找零问题(C++)
  4. Kudu的优点
  5. Hadoop2.X分布式集群部署
  6. pat1052. Linked List Sorting (25)
  7. 【防火墙】DMZ
  8. iis部署网站打不开
  9. 一些实用的浏览器meta
  10. Python异常处理及元类