我仍在尝试了解如何正确构建 ember.js 应用程序。因此,这可能是我尝试解决此问题的方式的系统性问题。话虽如此,我将尝试用几种不同的方式问同一个问题......
在下面的代码示例中,创建记录后,如何将其添加到列表中,并将 isEditing 属性设置为 true?
我可以从其阵列控制器访问特定的对象控制器吗?
每个任务都有一个视图状态和一个编辑状态。创建新任务时,如何让它最初出现在编辑状态?
App.TasksController = Ember.ArrayController.extend({
actions: {
createTask: function(){
var task = this.store.createRecord('task');
task.save();
}
}
});
App.TaskController = Ember.ObjectController.extend({
isEditing: false,
actions: {
toggleEditing: function(task) {
if(this.isEditing){
task.save();
}
this.set('isEditing', ! this.isEditing );
}
}
});
<script type="text/x-handlebars" data-template-name="tasks">
<ul>
{{#each task in controller}}
{{render "task" task}}
{{/each}}
<li {{action "createTask"}} >
New Task
</li>
</ul>
</script>
<script type="text/x-handlebars" data-template-name="task">
<li {{action "toggleEditing" task on="doubleClick"}} >
{{#if isEditing }}
{{textarea value=title cols="80" rows="6"}}
{{else}}
{{title}}
{{/if}}
</li>
</script>