AngularJS 不保留表单中复选框列表中的选定项目
AngularJS not keeping selected items from checkbox list in a form
我想保存一个复选框列表中的选定项目列表,该列表由 angular 服务生成,如下所示。
不幸的是,我的 "job" 对象只保存最后一个选中复选框的状态,而不是列表中所有选中复选框的 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>
目前,将完全相同的模型 (job.selectedPeople) 分配给每一行,并且每次单击时都会将复选框的状态添加到 selectedPeople 的末尾。这意味着 selectedPeople 充当所有点击的历史记录,而不是当前状态的记录。
您可以使用 $index 指定重复中的每一行都以其自己的数组元素为模型:
ng-model="selectedPeople[$index]"
然后您可以删除它,因为数组将通过数据绑定自动更新:
$scope.selectedPeople.push(id + " selected");
helloWorld.selectedPeople = $scope.selectedPeople;
更一般地说,我认为将工作和人员更清楚地分开会有所帮助,但希望以上内容会有所帮助。
这是一个 运行 代码,您的主要错误是为每个输入使用一个 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)" />
这是代码,希望对你有帮助。
我想保存一个复选框列表中的选定项目列表,该列表由 angular 服务生成,如下所示。
不幸的是,我的 "job" 对象只保存最后一个选中复选框的状态,而不是列表中所有选中复选框的 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>
目前,将完全相同的模型 (job.selectedPeople) 分配给每一行,并且每次单击时都会将复选框的状态添加到 selectedPeople 的末尾。这意味着 selectedPeople 充当所有点击的历史记录,而不是当前状态的记录。
您可以使用 $index 指定重复中的每一行都以其自己的数组元素为模型:
ng-model="selectedPeople[$index]"
然后您可以删除它,因为数组将通过数据绑定自动更新:
$scope.selectedPeople.push(id + " selected");
helloWorld.selectedPeople = $scope.selectedPeople;
更一般地说,我认为将工作和人员更清楚地分开会有所帮助,但希望以上内容会有所帮助。
这是一个 运行 代码,您的主要错误是为每个输入使用一个 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)" />
这是代码,希望对你有帮助。