Предоставлено javascript noob (в лучшем случае). Следующий код работает нормально. Любые идеи о том, как сохранить один и тот же подход "инициализатор" и заставить его работать без использования __proto__
и без преобразования всего в конструкторские функции?
var Employee =
{
paygrade: 1,
name: "",
dept: "general",
init: function()
{
return this;
},
salary: function()
{
return this.paygrade * 30000;
}
};
var WorkerBee =
{
paygrade: 2,
projects: ["Project1", "Project2"],
init: function()
{
this.__proto__ = Inherit_Employee; // Inherit My Employee "Pseudo Prototype"
return this;
}
};
var SalesPerson =
{
dept: "Sales",
quota: 100,
init: function()
{
this.__proto__ = Inherit_WorkerBee; // Inherit My WorkerBee "Pseudo Prototype"
return this;
}
};
var Engineer =
{
dept: "Engineering",
machine: "im the start machine",
init: function()
{
this.__proto__ = Inherit_WorkerBee; // Inherit My WorkerBee "Pseudo Prototype"
return this;
}
};
var Inherit_Employee = Object.create(Employee).init(); // Create My Employee Pseudo-Prototype
var Inherit_WorkerBee = Object.create(WorkerBee).init(); // Create My WorkerBee Pseudo-Prototype
var jane = Object.create(Engineer).init();
var jill = Object.create(Engineer).init();
У меня есть один подход, который работает, но мне интересно, есть ли более эффективный подход. Пока что то, что я сделал, заменяет строки, ссылающиеся на __proto__
на вызов моей собственной функции наследования, подобной этой.
init: function()
{
inherit(this, WorkerBee); // Inherit WorkerBee
return this;
}
И это моя функция inherit()
function inherit( childObject, parentObject )
{
// childObject inherits all of parentObjects properties
//
for (var attrname in parentObject)
if ( childObject[attrname] == undefined )
childObject[attrname] = parentObject[attrname];
// childObject runs parentObject 'init' function on itself
//
for (var attrname in parentObject)
if ( typeof parentObject[attrname] == "function" )
if ( attrname == 'init' )
parentObject[attrname].call(childObject);
}