我在这里使用公认的答案来实现继承:Javascript继承:调用超构造函数还是使用原型链? 所以我有一个从 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 对象将是: { 姓名:"迈克", 性别:"无" }
有没有办法在不显式设置每个属性的情况下执行此操作?
var _a = new ClassA();
_a.name = _b.name;
_a.sex = _b.sex;
我不想每次向 ClassA 添加新属性时都必须更改代码
如果对象类型仅由检查/匹配键确定,则创建适配器是一个简单的解决方案。如果要检查原型以确定对象类型,则可以在适配器中为 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));