javascript - 如何在 JavaScript 中进行原型(prototype)继承?

标签 javascript inheritance prototype

我尝试了多种方法,但都做不到。

在下一个示例中,我希望士兵获取人员的所有属性,并允许添加更多属性。如何正确地做到这一点?

function Person(name, age) {
    this.name = name;
    this.age = age;
}

Person.prototype.hi = function (message) {
    console.log(message + "!!!");
};

var Soldier = new(Person); // it is not the way to do it

Soldier.prototype.good_hi = function (message) {
    console.log("Sir! " + message + ", sir!");
};

最佳答案

您没有 Soldier 构造函数。你需要先做到这一点。然后,您将 Person 构造函数应用于新的 Soldier 实例。

function Person(name, age) {
    this.name = name;
    this.age = age;
}

Person.prototype.hi = function (message) {
    console.log(message + "!!!");
};

function Soldier(name, age) {
    Person.apply(this, arguments);
}

Soldier.prototype = Object.create(Person.prototype); // is better
Soldier.prototype.constructor = Soldier;

Soldier.prototype.good_hi = function (message) {
    console.log("Sir! " + message + ", sir!");
};

然后像这样使用它:

var s = new Soldier("Bob", 23);

s.good_hi("Hello");

演示: http://jsfiddle.net/3kGGA/

关于javascript - 如何在 JavaScript 中进行原型(prototype)继承?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13334476/

相关文章:

javascript - 在 jquery datepicker 的标题中显示当前日期

javascript - 自定义表单字段的 z-index 问题(选择)

entity-framework - EF6 中是否修复了 TPT 继承的性能问题?

java - 属性的 OOP 继承

javascript - 为什么这个 Object.create() 原型(prototype)对象不访问 Constructor 对象的属性?

javascript - Jasmine spy 与兑现 promise

javascript - 如何将多个 SVG 转换为一张 PNG 图像?

c++ - 在成员构造函数之后调用基类构造函数

c++ - 将 header 包含到 .h 文件中

Javascript __proto__、对象和函数