.bind('all', 'update')上的主干怪异类型错误错误
Backbone weird TypeError error on .bind('all', 'update')?
我希望我的ApplicationView
监听路由器上的所有事件。如果我这样做,它就会起作用:
this.model.router.on('route:myroute1, 'update');
this.model.router.on('route:myroute2, 'update');
this.model.router.on('route:myroute3, 'update');
当我尝试绑定all
事件时:
this.model.router.bind('all', 'update');
我得到了这个可怕的错误:
TypeError: all[i].apply 不是函数
all[i].apply(all[i + 1] || this, args);
视图(定义为 requirejs 模块):
define(['backbone', 'lodash'], function(Backbone, _) {
return Backbone.View.extend({
el: 'body',
initialize: function() {
this.model.router.bind('all', 'update');
_.bindAll(this, 'render', 'update');
this.render();
},
render: function() { },
update: function(route) {
this.$el
.find('.nav-collapse a[href=#'+ route +']')
.parent()
.addClass('active')
.siblings()
.removeClass('active');
}
});
});
虽然这是原始源代码中发生错误的地方:
// Execute "all" callbacks.
if (all) {
args = [event].concat(rest);
for (i = 0, length = all.length; i < length; i += 2) {
all[i].apply(all[i + 1] || this, args);
}
}
on()
/bind()
的第二个参数应该是一个函数。这是一个未记录的功能,您可以传递一个字符串吗?在这种情况下,它调用该方法的对象是什么?你确定它在你的第一个案例中有效吗?
如果改为这样做会发生什么?
this.model.router.bind('all', this.update);
相关文章:
- Node.js v6.2.0类扩展不是函数错误
- Jquery菜单操作不稳定,定位不正确,存在一般错误
- document.open/document.write没有正确地清除chrome中的文档——这是chrome的错误吗
- 试图在引导模式内动态生成图表,得到offsetWidth错误
- 为什么会出现错误;未捕获的类型错误:undefined不是函数;
- 我如何修复包含在captcha的addthis中的错误
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 节点是否需要模块传递带有方括号的arg?这是个错误吗
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- CKFinder 3为所选文件返回错误的URL
- 同位素库错误:未捕获错误无布局模式包装生产线8
- 铬:“;未捕获的语法错误:意外的标记:"
- 如何通过自己获得Chrome扩展的用户反馈/错误报告
- 相位器状态未捕获参考错误
- /undefined在我的404错误日志中多次出现
- Javascript未捕获语法错误意外的标识符错误
- javascript:如何在antlr生成的Lexer中进行错误处理
- Angularjs工厂注入错误
- 可以设置“;文件名"发生错误时显示的内联脚本标记的
- 为什么忽略了eval()代码中的语法错误