问题
I have problems to understand how ng-change works. I have a list of user to invite to join an auction. I want to do this with a checkbox. If the user is checked, his name has to be saved into an array. And later i will invite them(i just know how to do this). But i don't understand how to use the checkbox. I did something like this:
<ul class="list-group" ng-repeat="user in users">
<li class="list-group-item" ng-hide="user.name == profile">
<img ng-src="{{user.img}}" class="image2" >
<div class="username"> {{user.name}}</div>
<div class="userrole"> {{user.role}} </div>
<div class="usercompany">{{user.company}}</div>
<input type="checkbox" ng-model="isChecked" ng-change="insertinvited(user.name)">
</li>
</ul>
And in my controller:
$scope.invited = [];
$scope.insertinvited= function (name) {
if($scope.isChecked){
$scope.invited.push(name)
} else {
console.log($scope.invited);
}
};
But this is not working, in the console the array is always empty.
回答1:
The problem in your code is that your checkbox model (isChecked
) is used by all the users
you ngRepeated on:
<ul class="list-group" ng-repeat="user in users">
...
<input type="checkbox" ng-model="isChecked" ng-change="insertinvited(user.name)">
</ul>
I suggest you to have a checkbox model for each user:
<input type="checkbox" ng-model="user.isChecked" ng-change="insertinvited(user)">
Note that in your ng-change
, I pass the whole user
object, and not only user.name
(because I will also need the user.isChecked
property).
Here is the "new" insertinvited()
function:
$scope.insertinvited = function(user) {
if(user.isChecked) {
$scope.invited.push(user.name);
} else {
var toDel = $scope.invited.indexOf(user);
$scope.invited.splice(toDel);
}
}
回答2:
What you need here is isChecked
for all the items in ng-repeat
and not just as single variable. So, I changed your checkbox
like:
<input type="checkbox" ng-model="user.isChecked" ng-change="insertinvited(user)">
Here's working example:
angular.module("myApp", [])
.controller("myCtrl", function($scope) {
$scope.users = [{
name: "test1",
role: "manager",
company: "google",
img: ""
}];
$scope.invited = [];
$scope.insertinvited = function(user) {
if (user.isChecked) {
$scope.invited.push(user.name)
}
console.log($scope.invited);
};
})
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="myApp" ng-controller="myCtrl">
<ul class="list-group" ng-repeat="user in users">
<li class="list-group-item" ng-hide="user.name == profile">
<img ng-src="{{user.img}}" class="image2">
<div class="username"> {{user.name}}</div>
<div class="userrole"> {{user.role}} </div>
<div class="usercompany">{{user.company}}</div>
<input type="checkbox" ng-model="user.isChecked" ng-change="insertinvited(user)">
</li>
</ul>
</div>
EDIT: However, doing it this way, you would need to handle removal also. I'd suggest you go with following approach instead.
Explanation: On change of any checkbox value, you filter all the users with isChecked
set to true
.
angular.module("myApp", [])
.controller("myCtrl", function($scope) {
$scope.users = [{
name: "test1",
role: "manager",
company: "google",
img: ""
}];
$scope.invited = [];
$scope.insertinvited = function() {
$scope.invited = $scope.users.filter(obj => obj.isChecked)
$scope.invited = $scope.invited.map(obj => obj.name)
console.log($scope.invited);
};
})
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="myApp" ng-controller="myCtrl">
<ul class="list-group" ng-repeat="user in users">
<li class="list-group-item" ng-hide="user.name == profile">
<img ng-src="{{user.img}}" class="image2">
<div class="username"> {{user.name}}</div>
<div class="userrole"> {{user.role}} </div>
<div class="usercompany">{{user.company}}</div>
<input type="checkbox" ng-model="user.isChecked" ng-change="insertinvited(user)">
</li>
</ul>
</div>
回答3:
Use it
<input type="checkbox" id="{{'j' + $index}}" name="{{'j' + $index}}" ng-model="tasks.Checked" ng-change="checkinTask(tasks)"
This Part from controller.
$scope.checkinTask = function (task) {
if (task.Checked === true) {
task.Lineclass = "checkedTask";
$scope.disabled = false;
trash.removeClass("disabled");
} else {
task.Lineclass = "";
}
var checkedExist = false;
tasks.forEach(function (v) {
if (v.Checked) {
checkedExist = true;
}
});
if (!checkedExist) {
$scope.disabled = true;
trash.addClass("disabled");
}
};
来源:https://stackoverflow.com/questions/43676631/angularjs-checkbox-and-ng-change