我想从复选框列表中保存所选项目的列表,使用角度服务生成如下。
不幸的是,我的“作业”对象仅保留最后一个选中复选框的状态,而不是列表中所有选中复选框的id值。
有谁能告诉我,我做错了什么?
使用整个示例的Plunker:http://plnkr.co/edit/znLy9EqUMZN6kRzNnl07?p=preview
<script type="text/javascript">
var app = angular.module('helloWorldApp', []);
app.service('HelloWorldService', function() {
var model = this;
var people = [{
"id": 0,
"firstName": "John",
"lastName": "Doe",
"expertise": "Programmer",
"checked": false
}, {
"id": 1,
"firstName": "Mary",
"lastName": "Jane",
"expertise": "Manager",
"checked": false
}];
model.getPeople = function() {
return people;
};
});
app.controller('HelloWorldController', ['$scope', 'HelloWorldService',
function($scope, HelloWorldService) {
var helloWorld = this;
// why this does not work?
// helloWorld.people = function() { return HelloWorldService.getPeople(); };
// why this one works?
helloWorld.people = HelloWorldService.getPeople();
$scope.selectedPeople = [];
helloWorld.selectedPeople = [];
$scope.createNewJob = function() {
console.log("Object: " + JSON.stringify($scope.job));
};
$scope.addPerson = function(id) {
// how can I keep a list of selected people in my ng-model object?
//helloWorld.selectedPeople.push(id + " selected");
$scope.selectedPeople.push(id + " selected");
helloWorld.selectedPeople = $scope.selectedPeople;
console.log($scope.selectedPeople);
}
}
]);
<tbody ng-controller="HelloWorldController as helloWorld">
<tr ng-repeat="person in helloWorld.people">
<td>
<input type="checkbox" name="peopleList[]" ng-model="job.selectedPeople" ng-click="addPerson(person.id)" value="{{person.id}}" />
<label>{{person.firstName}} {{person.lastName}}</label>
</td>
<td>
{{person.expertise}}
</td>
</tr>
</tbody>
答案 0 :(得分:1)
目前,每个行都分配了完全相同的模型(job.selectedPeople),并且每次单击时,复选框的状态会添加到selectedPeople的末尾。这意味着selectedPeople充当所有点击的历史记录,而不是当前状态的记录。
您可以使用$ index指定repeat中的每一行都在其自己的数组元素上建模:
ng-model="selectedPeople[$index]"
然后您可以删除它,因为数组将通过数据绑定自动更新:
$scope.selectedPeople.push(id + " selected");
helloWorld.selectedPeople = $scope.selectedPeople;
更一般地说,我认为有助于更明确地分离工作和人员,但希望上述内容有所帮助。
答案 1 :(得分:1)
这是一个正在运行的代码,你的主要错误是为每个输入使用ng-model,它是你可以放在表单元素上的控制器范围。
我使用ng-checked
指令来定义是否必须选中复选框。
$scope.isChecked = function (id) {
return $scope.selectedPeople.indexOf(id) > -1;
}
和html
<input type="checkbox" name="peopleList[]" ng-checked="isChecked(person.id)" ng-click="addPerson(person.id)" />
这是代码,希望对您有所帮助。