gpt4 book ai didi

javascript - 向继承类添加非继承函数 - Javascript

转载 作者:行者123 更新时间:2023-11-28 01:36:15 26 4
gpt4 key购买 nike

我是 Javascript 面向对象编程的新手。昨天我读到了 javascript 中的 prototypeprototype.constructor 以及它们如何在 Javascript 继承中发挥作用。

我创建了一个 JavaScript 函数,继承自父函数之一。但我希望这个子函数的一些方法不被它的子函数继承。

也就是说,

function A //parent
|
|`callA()
`makeA()

这是主要的父类。

function B //child of A
|
|` callB() //can be inherited
|` makeB() //cannot be inherited
|` callA() //inherited
` makeA() //inherited

B 是我想编写的子函数。

function C //child of B
|
|` callC();
|` makeC();
|` callB();
|` callA();
` makeA();

我是这样写的:

function A(){}
A.prototype.callA = function()
{
alert('CallA');
}
A.prototype.makeA = function()
{
alert('makeA');
}

function B(){
function makeB(){ //This is not working I am not able to call makeB with B's object
alert('makeB');
}
}
B.prototype = new A();
B.prototype.constructor = B;
B.prototype.callB = function()
{
alert('callB');
}
function C(){}
C.prototype = new C();
C.prototype.constructor = C;
C.prototype.callC = function()
{
alert('callC');
}
C.prototype.makeC = function()
{
alert('makeC');
}

$(document).ready(function(){
var b = new B();
var c = new C();
$(document).click(function(){
c.callB();
c.callC();
b.callB();
b.makeB(); //not being called
});
});

这部分在JS继承中怎么做。派生对象的私有(private)函数。

最佳答案

您可以做的一件事是将 makeB 方法添加到您的实例中,作为 B 构造函数的一部分,而不是将其放入将从 C 继承的原型(prototype)中:

function B(){
this.makeB = function(){
//..
};
}

但是,要实现此功能,您需要使用 Object.createe 直接从父原型(prototype)继承,而不是从父类的实例继承:

B.prototype = Object.create(A.prototype);
B.prototype.constructor = B;

IE8 不支持 Object.create,因此您可能需要为其找到一个填充程序。

http://kangax.github.io/es5-compat-table/#Object.create

<小时/>

也就是说,我冒昧地说我的建议可能不是解决问题的最佳方法。

第一种选择是将这些隐藏方法公开。您确定要经历隐藏它们的麻烦吗?

第二种选择是简单地使用静态函数作为私有(private)方法:

function makeB(obj){
obj.callB();
}

关于javascript - 向继承类添加非继承函数 - Javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21507093/

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