Weakmap引用在继承中丢失

时间:2015-07-14 21:43:21

标签: javascript class ecmascript-6 private-members

我在使用javascript中的私有成员时遇到了一个问题,我无法自行解决。

"use strict";
var privateData = new WeakMap();


class Fruit{
    constructor(name){
        privateData.set(this, {name: name});
    }

    name(){
        return privateData.get(this).name;
    }
}

class Orange extends Fruit{
    constructor(){
        super("Orange");
    privateData.set(this, {color: "blue"});
    }

    color(){
        return privateData.get(this).color;
    }
}

var fruit = new Fruit("Apple");
alert(fruit.name());
var orange = new Orange();
alert(orange.name());

第一输出:Apple 第二输出:未定义

我的猜测是,我正在覆盖'this',因为如果我删除

return privateData.get(this).color;

它有效。

1 个答案:

答案 0 :(得分:3)

是的,对象是唯一的,并且您使用this实例作为密钥两次。第二次set调用将覆盖第一次调用的值,并且仅保留具有.color属性的对象。

最简单的解决方案是每个属性使用一个弱映射:

var privateNames = new WeakMap();
class Fruit {
    constructor(name) {
        privateNames.set(this, name);
    }
    get name() {
        return privateNames.get(this);
    }
}

var privateColors = new WeakMap();
class Orange extends Fruit {
    constructor() {
        super("Orange");
        privateColors.set(this, "blue");
    }
    get color() {
        return privateColors.get(this);
    }
}

或者,您必须改变存储的data对象:

var privateData = new WeakMap();
class Fruit {
    constructor(name) {
        privateData.set(this, {name: name});
    }
    get name() {
        return privateData.get(this).name;
    }
}

class Orange extends Fruit {
    constructor() {
        super("Orange");
        privateData.get(this).color = "blue";
    }
    get color() {
        return privateData.get(this).color;
    }
}