让我们假设我已经正确设置了一切。我有一个型号App.User
,我有一个控制器App.UsersIndexUserController
。Ember.js itemController和模型和控制器混淆
GOOD GOOD GOOD GOOD GOOD
以下视图模板...
<script type="text/x-handlebars" data-template-name="users_index_template">
{{#each user in users}}
{{log user}}
{{#linkTo users.user user}}{{user.name}}{{/linkTo}}
{{/each}}
</script>
...这个输出以下的浏览器的console.log ...
<App.User:ember258> { created_at="2013-03-05T01:51:15Z", id=76 ... etc ... }
很坏很坏很坏很坏的坏
然而,用我的模板itemController
指令,像这样......
<script type="text/x-handlebars" data-template-name="users_index_template">
{{#each user in users itemController="usersIndexUser"}}
{{log user}}
{{#linkTo users.user user}}{{user.name}}{{/linkTo}}
{{/each}}
</script>
时......这在输出浏览器的控制台下面。登录...
<App.UsersIndexUserController:ember253> { target=<Ember.ArrayController:ember245> ... etc ... }
我期待{{log user}}
为这两种情况返回一个App.User
的实例。但是,如上所示,使用itemController
指令时将返回App.UsersIndexUserController
的实例,如果不使用itemController
指令,则返回App.User
的实例。
如果我的App.UsersIndexUserController
明确返回一些对象,以致在上述两种情况下,{{log user}}
将返回App.User
?
App.UsersIndexUserController = Ember.ObjectController.extend({
});
我使用Ember.js V1.0.0-RC1
// Version: v1.0.0-rc.1
// Last commit: 8b061b4 (2013-02-15 12:10:22 -0800)
我打算仔细考虑一下。倾向于你是对的。 – 2013-03-10 19:27:42