为了账号安全,请及时绑定邮箱和手机立即绑定

new.target是es6特性?? 这两处分别代表啥

new.target是es6特性?? 这两处分别代表啥

ITMISS 2019-03-04 17:59:27
请教let PersonType2 = (function() {"use strict";const PersonType2 = function(name) {    // 确认函数被调用时使用了 new    if (typeof new.target === "undefined") {        // 这两处new.target分别代表啥        throw new Error("Constructor must be called with new.");    }    this.name = name;}Object.defineProperty(PersonType2.prototype, "sayName", {    value: function() {        // 确认函数被调用时没有使用 new        if (typeof new.target !== "undefined") {            // 这两处new.target分别代表啥            throw new Error("Method cannot be called with new.");        }        console.log(this.name);    },    enumerable: false,    writable: true,    configurable: true});return PersonType2;}());
查看完整描述

1 回答

?
森栏

TA贡献1810条经验 获得超5个赞

new.target属性允许你检测函数或构造方法是否是通过new运算符被调用的。在通过new运算符被初始化的函数或构造方法中,new.target返回一个指向构造方法或函数的引用。在普通的函数调用中,new.target 的值是undefined。

new.target语法由一个关键字"new",一个点,和一个属性名"target"组成。通常"new."的作用是提供属性访问的上下文,但这里"new."其实不是一个真正的对象。不过在构造方法调用中,new.target指向被new调用的构造函数,所以"new."成为了一个虚拟上下文。

new.target属性是一个可以被所有函数访问的元属性。在箭头函数中,new.target指向外围函数的new.target。


查看完整回答
反对 回复 2019-03-05
  • 1 回答
  • 0 关注
  • 386 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号