伙计们,我在选择下拉列表时遇到问题。取消选中复选框时,我想从angularJS中的数组刷新下拉列表。基本上,我正在尝试开发一种表单,在该表单中,我将在下拉列表中选择一家价值控股公司,并且所有下拉列表均被禁用,并且选中了我的复选框。当我释放下拉列表中的选定值时,它保持不变。取消选中复选框时,我想刷新下拉菜单。
这是代码。
<div class="col-md-6 col-sm-6">
<select id="dropdown1" ng-model="of" class="form-control col-md-7 col-xs-12" ng-click="dropdown()">
<option ng:repeat=" officet in officetypes" value="{{officet.headoffice}}">{{officet.headoffice}}</option>
</select>
</div>
<input id="Checkbox1" ng-model="checkboxvalue" type="checkbox" name="abc" value="bca" ng-click="check()" />Is Main Entity
$scope.officetypes = [
{
headoffice: 'Branches',
description: 'Branches'
},
{
headoffice: 'Holding Company',
description: 'Holding Company'
},
{
headoffice: 'Subsidiaries',
description:'Subsidiaries'
},
{
headoffice: 'Ware house',
description: 'Ware house'
}];
$scope.check = function () {
alert($scope.checkboxvalue + " Checked");
//document.getElementById('dropdown1').disabled = true;
if ($scope.temp === 0) {
document.getElementById('dropdown1').disabled = true;
document.getElementById('Dropdown2').disabled = true;
document.getElementById('Dropdown3').disabled = true;
$scope.temp = 1;
}
else if ($scope.temp === 1) {
document.getElementById('dropdown1').disabled = false;
document.getElementById('Dropdown2').disabled = false;
document.getElementById('Dropdown3').disabled = false;
document.getElementById('dropdown1').selectedIndex = 1;
$scope.temp = 0;
}
else if ($scope.temp === 2) {
document.getElementById('dropdown1').disabled = false;
document.getElementById('Dropdown2').disabled = false;
document.getElementById('Dropdown3').disabled = false;
$scope.temp = 0;
}
}
$scope.dropdown = function () {
if ($scope.of === 'Holding Company') {
$scope.checkboxvalue = true;
document.getElementById('dropdown1').disabled = true;
document.getElementById('Dropdown2').disabled = true;
document.getElementById('Dropdown3').disabled = true;
document.getElementById('Checkbox1').checked = true;
$scope.temp = 2;
alert($scope.temp);
temp = 0;
}
else if ($scope.of !== 'Holding Company') {
$scope.checkboxvalue = false;
document.getElementById('dropdown1').disabled = false;
document.getElementById('Dropdown2').disabled = false;
document.getElementById('Dropdown3').disabled = false;
$scope.temp = 0;
}
if ($scope.of === 'Subsidiaries') {
document.getElementById('Dropdown3').disabled = true;
}
if ($scope.of === 'Branches') {
document.getElementById('dropdown1').disabled = false;
document.getElementById('Dropdown2').disabled = false;
document.getElementById('Dropdown3').disabled = false;
}
}
最佳答案
您可以检查此答案,这可能对您有帮助
$scope.of = 0 ;
此模态值为零,以重置下拉菜单
http://plnkr.co/edit/h5em3jDXr049LOe86Fvm?p=preview