ES7类:在构造函数之外声明属性

时间:2016-01-20 08:25:33

标签: javascript ecmascript-7

在构造函数内部声明变量与外部之间有什么区别吗?

对于函数,'this'的约束方式不同,但对于变量,我无法弄清楚是否存在差异。

class Widget {
    constructor(constructorName) {
    this.constructorName = constructorName;
  }
  nonConstructorName = "nonConstructorName1";
}



var myWidget = new Widget("myConstructorName1");

console.log(myWidget.constructorName); // "myConstructorName1"
console.log(myWidget.nonConstructorName); // "nonConstructorName1"

myWidget.constructorName = "myConstructorName2";
myWidget.nonConstructorName = "nonConstructorName2";

console.log(myWidget.constructorName); // "myConstructorName2"
console.log(myWidget.nonConstructorName); // "nonConstructorName2"

console.log(myWidget.prototype.constructorName); // "undefined"
console.log(myWidget.prototype.nonConstructorName); // "undefined"

console.log(myWidget.__proto__.constructorName); // "undefined"
console.log(myWidget.__proto__.nonConstructorName); // "undefined"

var myNewWidget = new Widget("myConstructorName3");

console.log(myNewWidget.nonConstructorName); // "nonConstructorName1"

1 个答案:

答案 0 :(得分:5)

在@ merianos-nikos的评论中回答......

"这里的方法是使用私有的构造函数的范围来存储私有数据。对于有权访问此私有数据的方法,它们也必须在构造函数中创建,这意味着您要为每个实例重新创建它们。这是一种表现和记忆惩罚,但有些人认为惩罚是可以接受的。"

Private properties in JavaScript ES6 classes