gpt4 book ai didi

javascript - javascript中最简单的继承?

转载 作者:行者123 更新时间:2023-11-29 20:00:19 25 4
gpt4 key购买 nike

我正在尝试在 javascript 中使用 OOP。我正在尝试的是,

我有 2 个类 classAclassB。我在classB中继承classA。喜欢:

 function classA(){
this.propA = "somevalue of A";
}

function classB(){
classB.prototype = new classA(); //inheriting
classB.prototype.constructor = classB; //updating constructor defination
this.propB = "somevalue of B";
}

现在我创建了 classB 的对象:

var classBObject = new classB();

而不是尝试访问基类属性值:

alert(classBObject.propA);      //here i am expecting "somevalue of A"

但警报显示我是空的。谁能告诉我我在这里做错了什么?

最佳答案

将classB的原型(prototype)赋值移到构造函数之外:

function classA(){
this.propA = "somevalue of A";
}

function classB(){
// classB.prototype.constructor = classB;
// ^ no need for this, constructor will be overwritten
// by classB.prototype = new classA
this.propB = "somevalue of B";
}

classB.prototype = new classA; // assing prototype for classB here

关于javascript - javascript中最简单的继承?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14869242/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com