我在这里使用接受的答案来实现继承: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添加新属性时都要更改代码
答案 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));