在 python 中我可以做这样的事情
main.py
class MainClass:
def __init__(self):
self.name = "some_name"
def startDoingStuff(self):
print("I'm doing something boring")
def printName(self):
print("My name is " + self.name)
sub.py
import main
class Sub(main.MainClass):
def startDoingStuff(self):
print("I'm doing something interesting")
self.name = "sub"
sub = Sub()
sub.printName() # prints 'My name is some_name'
sub.startDoingStuff()
sub.printName() # prints 'My name is sub'
有等效的 JavaScript 吗?
如果基于原型的继承有点令人畏惧,您可能会考虑基于扩展的继承 http://ejohn.org/blog/simple-javascript-inheritance/.
一个真正基本的实现看起来像这样。 (上面链接的 John Resig 的实现更强大,但我认为这更具可读性,但具有相同的基本概念)
var extend = function(subTypeInit) {
var SuperType = this;
var SubType = function () {
function SuperTypeProxy(args) {
return SuperType.apply(this, args);
}
var base = new SuperTypeProxy(arguments);
subTypeInit.apply(base, arguments);
return base;
}
SubType.extend = extend.bind(SubType);
return SubType;
}
然后可以像这样使用:
var Main = function (name) {
var self = this;
self.name = name;
self.doSomething = function () {
console.log("something boring");
};
self.printName = function () {
console.log("Hi, I'm "+name);
};
};
Main.extend = extend.bind(Main); //Manually attach to first parent.
var Sub = Main.extend(function () {
var self = this;
self.doSomething = function () {
console.log("something interesting");
};
var superPrintName = self.printName;
self.printName = function () {
superPrintName();
console.log("And I'm a sub class");
};
});
var sub = new Sub("foo");
sub.doSomething(); //logs "something interesting"
sub.printName(); //logs "Hi, I'm foo" "And I'm a sub class"
这里有一些警告,你真的可能应该研究基于原型的继承,这才是 javascript 真正构建的目的。对于习惯了其他 OO 语言继承方法的人来说,基于扩展的继承更为自然,但缺点是这种方式继承会消耗更多资源;你正在创建很多函数(以及很多闭包),这些函数确实可以累加起来。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)