gpt4 book ai didi

javascript - AngularJS 不保留表单中复选框列表中的选定项目

转载 作者:行者123 更新时间:2023-12-02 16:35:49 25 4
gpt4 key购买 nike

我想保存从复选框列表中选择的项目列表,该列表是使用 Angular 服务生成的,如下所示。

不幸的是,我的“作业”对象仅保留最后选定的复选框的状态,而不是列表中所有选定复选框的 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]"

然后您可以删除它,因为数组将通过数据绑定(bind)自动更新:

$scope.selectedPeople.push(id + " selected");
helloWorld.selectedPeople = $scope.selectedPeople;

更一般地说,我认为这将有助于更清晰地分离工作和人员,但希望上述内容能有所帮助。

关于javascript - AngularJS 不保留表单中复选框列表中的选定项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27939738/

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