node-binary二进制解析器使用以下模式构建其对象:
exports.parse = function parse (buffer) {
var self = {...}
self.tap = function (cb) {...};
self.into = function (key, cb) {...};
...
return self;
};
如何从中继承我自己的,开明的解析器?这个模式是否有意设计使继承变得尴尬?
到目前为止,我唯一成功继承binary.parse(<something>)
所有方法的尝试是使用_.extend
:
var clever_parser = function(buffer) {
if (this instanceof clever_parser) {
this.parser = binary.parse(buffer); // I guess this is super.constructor(...)
_.extend(this.parser, this); // Really?
return this.parser;
} else {
return new clever_parser(buffer);
}
}
我的气味测试和其他人的气味测试都失败了。这有什么关于它的危险吗?
答案 0 :(得分:0)
怎么样:
var clever_parser = function ( buffer ) {
var parser = binary.parse( buffer );
_.extend( parser, clever_parser.methods );
return parser;
}
clever_parser.methods = {
foo: function () { ... },
bar: function () { ... }
};
binary.parse
函数返回一个普通对象(一个继承自Object.prototype
的对象),后来无法重定向其原型链接(除非使用__proto__
,但这不是 - 标准和弃用)。
因此,我们唯一能做的就是手动使用我们的方法扩展该对象......
顺便说一下,clever_parser
函数可以正常工作。您不必为构造函数和new
运算符而烦恼。
此外,您可以采取相反的方法:首先,创建继承方法的对象,然后使用binary.parse
函数中分配的属性对其进行扩展:
var clever_parser = function ( buffer ) {
var parser = Object.create( clever_parser.methods );
_.extend( parser, binary.parse( buffer ) );
return parser;
}
如果这种方法有效,它肯定比我上面的原始解决方案更好,因为这里生成的对象继承了你的方法(与上面相反,每个实例都包含方法作为自己的属性)。