gpt4 book ai didi

javascript - Ember.js hasMany 作为复选框列表

转载 作者:数据小太阳 更新时间:2023-10-29 05:46:45 25 4
gpt4 key购买 nike

我有以下两个模型:

App.Child = DS.Model.extend({
name: DS.attr('string')
});

和:

App.Activity = DS.Model.extend({
children: DS.hasMany('child',{async:true}),
name: DS.attr('string')
});

对于 hasMany 关系,我想使用复选框在现有子项之间进行选择。

例如,我有这三个 child :

App.Child.FIXTURES = [
{ id: 1, name: 'Brian' },
{ id: 2, name: 'Michael' },
{ id: 3, name: 'James' }
];

用户应该能够在创建或编辑事件时使用复选框来选择要添加到hasMany 关系的子项。

我创建了一个 JSFiddle 来说明我的问题:http://jsfiddle.net/Dd6Wh/ .单击“创建新事件”以查看我正在尝试做什么。

基本上它与 Ember.Select [ ... ] multiple="true" 相同,但用于复选框。

使用 Ember.js 进行此类操作的正确方法是什么?

最佳答案

您可以在each View 帮助程序中使用itemController 来管理选择。在下面的代码中,我创建了一个名为 ChildController 的代码:

App.ChildController = Ember.ObjectController.extend({    
selected: function() {
var activity = this.get('content');
var children = this.get('parentController.children');
return children.contains(activity);
}.property(),
selectedChanged: function() {
var activity = this.get('content');
var children = this.get('parentController.children');
if (this.get('selected')) {
children.pushObject(activity);
} else {
children.removeObject(activity);
}
}.observes('selected')
});

使用 itemController,您可以公开一些属性和逻辑,而无需将其直接添加到您的模型中。在这种情况下,selected 计算属性和 selectedChanged 观察者。

在您的模板中,您可以使用 checkedBinding="selected" 绑定(bind)选择。因为 itemController 代理每个模型,将使用 itemcontroller 的 selected 属性,以及 {{name}} 绑定(bind),将查找模型的 name 属性:

<script type="text/x-handlebars" data-template-name="activities/new">
<h1>Create a new activity</h1>

{{#each childList itemController="child"}}
<label>
{{view Ember.Checkbox checkedBinding="selected"}}
{{name}}
</label><br />
{{/each}}
{{view Ember.TextField valueBinding="name"}}
<button {{action create}}>Create</button>
</script>

编辑模板中的相同方法:

<script type="text/x-handlebars" data-template-name="activities/edit">
<h1>Edit an activity</h1>

{{#each childList itemController="child"}}
<label>
{{view Ember.Checkbox checkedBinding="selected"}}
{{name}}
</label><br />
{{/each}}
{{view Ember.TextField valueBinding="name"}}
<button {{action update}}>Update</button>
</script>

这是一个关于这个工作的 fiddle http://jsfiddle.net/marciojunior/8EjRk/

组件版本

模板

<script type="text/x-handlebars" data-template-name="components/checkbox-select">
{{#each elements itemController="checkboxItem"}}
<label>
{{view Ember.Checkbox checkedBinding="selected"}}
{{label}}
</label><br />
{{/each}}
</script>

Javascript

App.CheckboxSelectComponent = Ember.Component.extend({   
/* The property to be used as label */
labelPath: null,
/* The model */
model: null,
/* The has many property from the model */
propertyPath: null,
/* All possible elements, to be selected */
elements: null,
elementsOfProperty: function() {
return this.get('model.' + this.get('propertyPath'));
}.property()
});

App.CheckboxItemController = Ember.ObjectController.extend({
selected: function() {
var activity = this.get('content');
var children = this.get('parentController.elementsOfProperty');
return children.contains(activity);
}.property(),
label: function() {
return this.get('model.' + this.get('parentController.labelPath'));
}.property(),
selectedChanged: function() {
var activity = this.get('content');
var children = this.get('parentController.elementsOfProperty');
if (this.get('selected')) {
children.pushObject(activity);
} else {
children.removeObject(activity);
}
}.observes('selected')
});

更新 fiddle http://jsfiddle.net/mgLr8/14/

希望对你有帮助

关于javascript - Ember.js hasMany 作为复选框列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19618602/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com