测试主干扩展构造函数继承的好方法是什么?
What is a good way to test for inheritance of Backbone-extended constructors?
如何测试一个构造函数是否扩展了另一个构造函数,Backbone.js风格,其中继承是通过Backbone的extend
方法设置的?不要说instanceof
:)。我说的不是物体。我说的是构造函数
。采用如下代码生成的构造函数:
var MyRouter = Backbone.Router.extend();
现在,在代码的另一个地方,您如何在其原型链的某个地方测试var my_router = new MyRouter
具有Backbone.Router.prototype
的属性?
我的解决方案是:
var inherits = function(child, parent) {
if (!_.isFunction(child) || !_.isFunction(parent))
throw new Error('`child` and `parent` must be functions.');
return _.reduce(Object.getPrototypeOf(child.prototype), function(memo, child_prototype__proto__) {
return _.contains(parent.prototype, child_prototype__proto__) && memo;
}, true);
}
所以,你可以这样做:
var MyRouter = Backbone.Router.extend();
inherits(MyRouter, Backbone.Router) // true
inherits(MyRouter, Backbone.Model) // false
这适用于单层Backbone风格的继承,其中Backbone的extend
函数如上所述。
之所以有效,是因为Backbone的extend
在建立原型链时执行以下操作,其中child
是您在最后得到的构造函数,parent
是您要扩展的构造函数:
var Surrogate = function(){ this.constructor = child; };
Surrogate.prototype = parent.prototype;
child.prototype = new Surrogate;
因此,由extend
产生的构造函数在其.prototype.__proto__
属性上拥有其父的所有原型属性。如果这是新的或令人困惑的,你可以在John Resig的博客上读到更多。实际上,"test".__proto__ === String.prototype
.
相关文章:
- 打破承诺链的好方法是什么
- 在JavaScript中拆分日期字符串的更好方法是什么
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- 处理浮点错误的最佳方法是什么
- 基于窗口宽度jquery的函数的替代方法是什么
- knex:根据结果创建数组的合适方法是什么
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- 使用Modernizr检测移动设备最可靠的方法是什么
- 确定var是否是javascript中的elementFinder对象的方法是什么
- 用javascript修复这个JSON对象字符串最干净的方法是什么
- 让会话值可用于JavaScript的好方法是什么
- 从AngularJs获取谷歌地图对象的正确方法是什么
- 使用ReactJS和Flux架构从服务器获取数据的正确方法是什么
- 列出没有 mysql 的元素的最佳方法是什么
- 克服错误的更优雅的方法是什么:需要对象说明符.当通过JXA通过Messages发送SMS时,参数没有对象说明符
- 使用较少代码隐藏和显示选择菜单内容的更好方法是什么?javascript
- 在 Javascript 中实现解耦代码/回调的正确方法是什么?
- 使用Javascript,获取元素的方法是什么,基于打开和关闭标记之间的文本
- 在d3.json中使用d3.csv组合多个csv文件数据输入的最佳方法是什么
- 直接在DOM事件处理程序中调用作用域函数的最短方法是什么