访问关联的 DS.model 到 DS.model 时似乎存在绑定问题array.firstObject
。所以下面小提琴中的路径是,App.person.parties.firstObject
但它似乎没有正确绑定。App.person.parties
绑定OK,可以在插座中使用,但firstObject
似乎从来没有工作过。有任何想法吗?
另外,我认为这不是最好的方法nextParty
-如果有人可以就如何构建它提供一些建议,将不胜感激!
JS:-
/* Flip this switch to compare. You should see 'Ember party' appear after 2s when it works */
var works = true;
window.App = Em.Application.create({
ready: function() {
App.set('person', App.store.find(App.Person, 1));
},
ApplicationView: Em.View.extend({templateName: 'application'}),
ApplicationController: Em.Controller.extend(),
Router: Em.Router.extend({
root: Em.Route.extend({
index: Em.Route.extend({
route: '/',
connectOutlets: function(router, context) {
router.get('applicationController').connectOutlet('dashboard', App.get('person'));
router.get('dashboardController').connectOutlet('nextParty', 'party',
App.get('person.nextParty')
);
}
})
})
}),
DashboardController: Em.Controller.extend({}),
DashboardView: Em.View.extend({
templateName: 'dashboard'
}),
PartyController: Em.Controller.extend({}),
PartyView: Em.View.extend({
templateName: 'party'
}),
Party: DS.Model.extend({
name: DS.attr('string')
}),
Person: DS.Model.extend({
firstName: DS.attr('string'),
lastName: DS.attr('string'),
parties: DS.hasMany('App.Party'),
nextParty: function() { return this.get('parties.firstObject'); }.property('parties.firstObject')
}),
store: DS.Store.create({
revision: 7,
adapter: DS.Adapter.create({
find: function(store, type, id) {
if (type == 'App.Person') {
if (works) {
store.load(type, id, {
id: 1,
firstName: 'John',
lastName: 'Jackson',
parties: [99]
});
} else {
setTimeout(function() {
store.load(type, id, {
id: 1,
firstName: 'John',
lastName: 'Jackson',
parties: [99]
});
}, 1000);
}
}
if (type == 'App.Party') {
setTimeout(function() {
store.load(type, id, {
id: 99,
name: 'Ember party'
});
}, 2000);
}
}
})
})
});
模板: -
<script type="text/x-handlebars" data-template-name="application">
<h1>Party app</h1>
{{outlet}}
</script>
<script type="text/x-handlebars" data-template-name="dashboard">
<h2>Hi {{content.firstName}} {{content.lastName}}</h2>
<h3>Next party</h3>
{{outlet nextParty}}
</script>
<script type="text/x-handlebars" data-template-name="party">
{{content.name}}
</script>