我正在尝试使用记录的 model.reload() 函数轮询更多数据
App.ModelViewRoute = Ember.Route.extend({
actions: {
reload: function() {
this.get('model').reload();
}
}
});
但我收到一条错误消息说...
undefined is not a function TypeError: undefined is not a function
有没有更好的方法来做到这一点,似乎我无法从路线以这种方式访问模型?
这是路由器
App.Router.map(function() {
this.route('video', { path: '/videos/:video_id' });
});
这是路线
App.VideoRoute = Ember.Route.extend({
model: function(params) {
return this.store.find('video', params.video_id);
},
actions: {
reloadModel: function() {
// PROBLEM HERE
// this.get('model').reload();
Ember.Logger.log('reload called!');
}
}
});
这是模型
App.Video = DS.Model.extend({
title: DS.attr('string'),
status: DS.attr('string')
});
还有模板
<script type="text/x-handlebars" data-template-name="application">
<h1>Testing model reloading</h1>
{{#link-to "video" 1}}view problem{{/link-to}}
{{outlet}}
</script>
<script type="text/x-handlebars" data-template-name="video">
<h1>Video</h1>
<h2>{{title}}</h2>
{{model.status}}
<p><button {{action 'reloadModel'}}>Reload model</button></p>
</script>
我在这里制作了这个问题的 jsbin:
http://jsbin.com/wofaj/13/edit?html,js,输出 http://jsbin.com/wofaj/13/edit?html,js,output
我真的不明白为什么重新加载会给我这个错误。任何建议将不胜感激。
Thanks