从继承的实例创建javascript基类对象

时间:2016-03-11 20:59:42

标签: javascript class inheritance prototype base

我在这里使用接受的答案来实现继承:Javascript inheritance: call super-constructor or use prototype chain?。所以我有一个继承自A类的B类.B类具有属于B类对象独有的原型的属性/函数。

编辑:为了更清楚,我已经设置了继承链,这不是我需要帮助的。对象定义如下:

function classA() {
    this.name= '';
    this.sex = '';
}

function classB(){
  classA.call(this, arguments);
  this.age= 0;
}

在我的代码中,我创建了一个新的B类对象并设置了一些属性:

var _b = new ClassB();
_b.name = 'mike';   -- name is a property of ClassA
_b.sex = 'none';    -- sex  a property of ClassA
_b.age = 20;        -- age is only a property of Classb

我正在调用一个只接受“类型”ClassA对象的API。所以我需要创建一个ClassA对象并将它的所有属性设置为来自_b的值,但只设置属于ClassA属性的属性。

在此示例中,新创建的ClassA对象将是:     {     名称:'mike',     性别:'无'     }

有没有办法在没有明确设置每个属性的情况下执行此操作?

var _a = new ClassA();
_a.name = _b.name;
_a.sex = _b.sex;

我不想每次向ClassA添加新属性时都要更改代码

1 个答案:

答案 0 :(得分:1)

如果对象类型仅由检查/匹配键确定,则创建适配器是一种简单的解决方案。如果要检查原型以确定对象类型,则可以在适配器中为 newObj 实例化该类型的空对象。

var foo = {
    a: 'alpha',
    b: 'beta',
};

var bar = {
    a: 'alfa',
    b: 'bravo',
    c: 'charlie'
};

function adapt(objA, objB) {//only copy properties common to objA from objB
    var newObj = {};
    for (var prop in objA) {
        var val = objB[prop];
        newObj[prop] = val;
    }

    return newObj;
}

console.log(adapt(foo, bar));