The following will achieve what you're looking for: (working jsFiddle). It uses the prototype chain in order to achieve classical inheritance.
function AnotherMan(name) {
this.name = name;
}
function Mr(name) {
AnotherMan.call(this, name); // Call the superclass's constructor in the scope of this.
this.name = "Mr. " + name; // Add an attribute to Author.
}
Mr.prototype = new AnotherMan(); // Set up the prototype chain.
Mr.prototype.constructor = Mr; // Set the constructor attribute to Mr.
var mrBean = new Mr("Bean");
You can generalize this into a function: (Another Working jsFiddle)
function extend(subClass, superClass) {
var F = function() {};
F.prototype = superClass.prototype;
subClass.prototype = new F();
subClass.prototype.constructor = subClass;
subClass.superclass = superClass.prototype;
if(superClass.prototype.constructor == Object.prototype.constructor) {
superClass.prototype.constructor = superClass;
}
}
and use it like this:
function AnotherMan(name) {
this.name = name;
}
function Mr(name) {
Mr.superclass.constructor.call(this, name);
this.name = "Mr. " + name;
}
extend(Mr, AnotherMan);
var mrBean = new Mr("Bean");