[英]Angular to disable ng-repeat checkbox based on value
我有一个使用ng-repeat显示的复选框列表,现在我需要根据特定值禁用某些复选框。
checkbox display code
<div class="checkbox">
<label ng-repeat="specific in specifications">
<input ng-click="onClick(specific, newObject[specific])" id="specifications_chk" value="{{specific}}" ng-model="newObject[specific]" type="checkbox">
{{specific}}
</label>
</div>
这是使用ng-click功能禁用复选框。
This is my controller code:
$scope.onClick = function(sp, checked){
if(sp == 'Sofa_Cleaning' && checked === true){
angular.element(document.getElementById('specifications_chk'))[0].disabled = true;
}
if(sp == 'Sofa_Cleaning' && checked === false){
angular.element(document.getElementById('specifications_chk'))[0].disabled = false;
}
};
html view:
在控制器代码是能够禁用仅第一值(IndepthHomeCleaning)
所以如何禁用Room_Cleaning, Kitchen_Cleaning,
和Carpet_cleaning
当Sofa_Cleaning
被checked
我是否坚持使用此功能,将不胜感激帮助
我不知道你为什么仍然坚持使用jQuery。 当您尝试禁用复选框时,您将通过id获取。
。
在html中,id对于当前html页面应该是唯一的。 您有重复的ID,并且尝试禁用时,使用[o]从数组中获取第一个值。
。
如果您严格希望使用同一方法解决方案,请使用以下方法将复选框使用类名代替id并使用angular元素并禁用。
需要禁用的位置应使用以下代码。 根据您的需要使用适当的代码。
angular.forEach(document.getElementsByClassName('checkbox1'), function(value, key) {
angular.element(value)[0].disabled = true;
debugger
});
使用ng-disabled
var angApp = angular.module('myApp', []); angApp.controller('MyController', function MyController($scope) { $scope.specifications = [{"text":"IndepthHomeCleaning ", "disabled":false, "checked":false}, {"text":"Room_Cleaning", "disabled":false, "checked":false}, {"text":"Kitchen_Cleaning", "disabled":false, "checked":false}, {"text":"BathroomCleaning", "disabled":false, "checked":false}, {"text":"Carpet_cleaning", "disabled":false, "checked":false}, {"text":"Sofa_Cleaning", "disabled":false, "checked":false}]; $scope.onClick = function(sp, checked){ console.log(sp, checked); if(sp.text == 'Sofa_Cleaning' && checked){ $scope.specifications[1].disabled = true; $scope.specifications[2].disabled = true; $scope.specifications[4].disabled = true; } if(sp.text == 'Sofa_Cleaning' && !checked){ $scope.specifications[1].disabled = false; $scope.specifications[2].disabled = false; $scope.specifications[4].disabled = false; } }; });
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> <div ng-app="myApp" ng-controller="MyController"> <div class="checkbox"> <label ng-repeat="specific in specifications" style="display:block"> <input ng-disabled="specific.disabled" ng-change="onClick(specific, specific.checked)" id="specifications_chk" value="specific.checked}" ng-model="specific.checked" type="checkbox"> {{specific.text}} </label> </div> </div>
我认为您已经使这一问题复杂化了。 您的数据对象应简化为如下所示
$scope.specifications = [
{name: 'Sofa_Cleaning', active: false},
{name: 'Carpet_Cleaning', active: false},
{name: 'Room_Cleaning', active: false},
{name: 'Kitchen_Cleaning', active: false},
{name: 'BathroomCleaning', active: false}
];
模板:
<input type="checkbox"
ng-bind="specific.name"
ng-model="specific.active"
ng-disabled="shouldDisable(specific)">
在您的控制器中
$scope.disableWhenSofaIsChecked = ['Room_Cleaning','Kitchen_Cleaning','Carpet_Cleaning'];
$scope.shouldDisable = function(specific) {
var disable = $scope.disableWhenSofaIsChecked;
if(disable.indexOf(specific.name) > -1) {
for(var obj in $scope.specifications) {
if(obj.name === 'Sofa_Cleaning') {
return obj.active;
}
}
}
return false;
}
编辑
因此,如果您要从API获取规范数据,则可以执行以下操作:
SomeApi
.get()
.then(function(results){
// Assuming it's a promise. End result is the same for a passed-in callback
// Assuming results is an array of names
$scope.specifications = results.map(function(item){
return {
name: item,
active: false
};
});
});
您的代码中的多个元素不应具有相同的ID。 您需要使元素ID唯一。
HTML:
<div ng-app ng-controller="LoginController">
<div class="checkbox">
<label ng-repeat="specific in specifications">
<input id="specifications_chk{{$index}}" ng-click="onClick(specific, newObject[specific])" value="{{specific}}" ng-model="newObject[specific]" type="checkbox" /> {{specific}}
<br>
</label>
</div>
</div>
JavaScript:
function LoginController($scope) {
$scope.specifications = ['IndepthHomeCleaning',
'Room_Cleaning',
'Kitchen_Cleaning',
'BathroomCleaning',
'Carpet_cleaning',
'Sofa_Cleaning'
];
$scope.newObject = {
'IndepthHomeCleaning': 1,
'Room_Cleaning': 2,
'Kitchen_Cleaning': 3,
'BathroomCleaning': 4,
'Carpet_cleaning': 5,
'Sofa_Cleaning': 6
};
$scope.onClick = function(sp, checked) {
if (sp == 'Sofa_Cleaning' && checked === true) {
angular.element(document.getElementById('specifications_chk1'))[0].disabled = true;
angular.element(document.getElementById('specifications_chk2'))[0].disabled = true;
angular.element(document.getElementById('specifications_chk4'))[0].disabled = true;
}
if (sp == 'Sofa_Cleaning' && checked === false) {
angular.element(document.getElementById('specifications_chk1'))[0].disabled = false;
angular.element(document.getElementById('specifications_chk2'))[0].disabled = false;
angular.element(document.getElementById('specifications_chk3'))[0].disabled = false;
}
};
}
JsFiddle: https ://jsfiddle.net/nikdtu/f7k3kcwn/
您正在使用“ id”属性,该属性对于每个DOM元素都应该是唯一的。 因此,您的解决方案肯定会只包含一个元素。 因此,您应该尝试使用类属性和document.getElementbyClass函数。
如果要更改specifications
数组,则需要新的数组和映射。 为每个规范定义新的行对象。 从您的规范访问规范行及其属性(处于活动状态或已禁用)。
http://jsfiddle.net/ms403Ly8/87/
function testCtrl($scope, $filter) {
$scope.specifications = ["IndepthHomeCleaning", "Room_Cleaning", "Kitchen_Cleaning", "Carpet_cleaning", "Sofa_Cleaning"];
$scope.specificationRows = [];
$scope.newRow = function(spec) {
var newSpec = {
SpecName: spec,
IsDisabled: false,
IsClicked: false
};
$scope.specificationRows.push(newSpec);
};
$scope.getRowObject = function(sp) {
return $filter('filter')($scope.specificationRows, {
SpecName: sp
})[0];
};
$scope.getRowStatus = function(spec) {
console.log($filter('filter')($scope.specificationRows, {
SpecName: spec
})[0].IsDisabled);
return $scope.getRowObject(spec).IsDisabled;
};
$scope.onClick = function(sp) {
$scope.getRowObject(sp).IsClicked = !$scope.getRowObject(sp).IsClicked;
if (sp == 'Sofa_Cleaning') {
$scope.getRowObject("Carpet_cleaning").IsDisabled = $scope.getRowObject(sp).IsClicked;
$scope.getRowObject("Kitchen_Cleaning").IsDisabled = $scope.getRowObject(sp).IsClicked;
$scope.getRowObject("Room_Cleaning").IsDisabled = $scope.getRowObject(sp).IsClicked;
}
};
}
getRowObject是示例。 也许这不是最佳实践。 您可以更改此功能。
不要使用jquery进行dom操作。
使用ng-change而不是ng-click。 这将是适当的。
在这里,我更新了一个punkr。
在这里作为简单示例,我已经完成了类似值5的操作,然后禁用了所有复选框。 否则,启用复选框。
https://jsfiddle.net/AvGKj/517/
注意 :我使用了一点旧插件。 请单独考虑逻辑
<div ng-controller="MyCtrl">
<table>
<tr ng-repeat="appObj in myAppObjects">
<td>
<input type="checkbox" ng-model="appObj.cb1"
ng-disabled="appObj.disable"
ng-change="Disable(appObj,myAppObjects)">
{{appObj.value}}
</td>
</tr>
</table>
{{myAppObjects}}
<br>list of checked items: {{checkedItems()}}
</div>
function MyCtrl($scope) {
$scope.myAppObjects = [
{id:1,value:'check1'},
{id:2,value:'check2'},
{id:3,value:'check3'},
{id:4,value:'check4'},
{id:5,value:'check5'}
];
$scope.Disable=function(appObj,list)
{
if(appObj.value=="check5")
{
for(var i=0; i<list.length;i++)
{
if(list[i].value!="check5")
{
if(appObj.cb1==true)
{
list[i].disable=true;
}
else{
list[i].disable=false;
}
}
}
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.