这是我的application.js文件
window.App = {
init: function() {
this.router = new PackageViewer();
Backbone.history.start();
}
};
这是在调用其他的packageviewer.js
window.PackageViewer = new Backbone.Router.extend({
routes : {
'':'home'
},
initialize:function(){
this.collection = new Package();
},
home:function(){
$('body').append("<h1>Welcome</h1>");
}
});
这是我的index.html的脚本标记,位于<body>
<script type="text/javascript">
$(document).ready(function (){
App.init();
});
</script>
当我运行时,我得到TypeError: 'undefined' is not a function (evaluating 'parent.apply(this, arguments)')
我无法理解这一点。救命啊!
答案 0 :(得分:8)
改变这个:
window.PackageViewer = new Backbone.Router.extend({
routes : {
'':'home'
}
到此:
window.PackageViewer = Backbone.Router.extend({
routes : {
'':'home'
}
因为在这里你应该只是扩展Backbone.Router,而不是创建一个新实例。
当你调用`this.router = new PackageViewer();
时,你在App.init中正确创建了一个新实例我使用虚拟包模型和集合测试了它并且它有效。
window.Package = Backbone.Model.extend({
});
window.Packages = Backbone.Collection.extend({
model: Package
});