ng-options отображает пустую выбранную опцию, даже если ng-модель определена
Я создал plunkr, чтобы подчеркнуть проблему, возможно, это потому, что источник ng-повтора является функцией, я не уверен, но до сих пор я пробовал все, чтобы решить эту проблему, и не мог чесотка.
plunkr: http://plnkr.co/edit/qQFsRM?p=preview
HTML-код
<html>
<head>
<script data-require="angular.js@1.2.0-rc1" data-semver="1.2.0-rc1" src="http://code.angularjs.org/1.2.0rc1/angular.js"></script>
<link rel="stylesheet" href="style.css" />
<script src="script.js"></script>
</head>
<body ng-app='myApp' ng-controller='mainCtrl'>
<ng-include src="'menu.html'">
</ng-include>
</html>
скрипт
var app = angular.module('myApp', []);
app.controller('mainCtrl', function($scope, $httpBackend){
$scope.model = {};
$scope.model.myJobs = {};
$scope.refreshJobs = function(){
}
});
app.controller('menuCtrl', function($scope){
$scope.model.locations = function(){
var loc = [];
loc[1] = 'Dublin';
loc[2] = 'Stockholm';
loc[3] = 'New Jersy';
$scope.model.selectedLocationDef = loc.indexOf('Dublin');
return loc;
}
$scope.model.selectedLocation = $scope.model.selectedLocationDef;
$scope.$watch('model.selectedLocation', function(location){
$scope.refreshJobs(location);
});
});
2 ответов
последнее, что я проверил, Angular не поддерживает возможность привязки ключей массива к ng-модели через ng-options. Однако вы можете имитировать это поведение, используя хэш объекта:
.HTML-код:<div ng-controller="menuCtrl">
<select ng-model="model.selectedLocation" ng-options="x.value as x.label for x in model.locations()">
</select>
</div>
сценарий.js:
$scope.model.locations = function(){
var loc = [{
value: 0,
label: 'Dublin'
}, {
value: 1,
label: 'Stockholm'
}, {
value: 2,
label: 'New Jersey'
}];
$scope.model.selectedLocation = 1; // Set default value
return loc;
}
имейте в виду, что это свяжет целые числа с вашей моделью, а не сами города. Если вы хотите, чтобы значение модели было Dublin
, Stockholm
или New Jersey
, просто do:
<div ng-controller="menuCtrl">
<select ng-model="model.selectedLocation" ng-options="name for name in model.locations()">
</select>
</div>
сценарий.js:
$scope.model.locations = function(){
var loc = ['Dublin', 'Stockholm', 'New Jersey'];
$scope.model.selectedLocation = 'Dublin'; // Set default value
return loc;
}
Если вы используете массив в качестве модели, то модель является строкой, а не числом. Поэтому вам нужно преобразовать число в строку. Просто попробуйте
$scope.model.selectedLocation = '1';