When I use track by
in ng-options
, Angular doesn't update the selectbox value even if I choose one of the values in the selectbox. After second try, it works as expected even though the model value is already set.
var myapp = angular.module('myapp', []);
myapp.controller('FirstCtrl', function ($scope) {
$scope.items = [
['ali', 'ali']
];
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular.js"></script>
<div ng-app="myapp">
<fieldset ng-controller="FirstCtrl">
value: {{selected}} <br><br>
<select
ng-options="item[0] as item[1] for item in items track by item[0]"
ng-model="selected"></select>
</fieldset>
</div>
It's actually explained in the docs (https://docs.angularjs.org/api/ng/directive/ngOptions - look for the paragraph "select as and track by")
It seems that you cannot use
track by
together with someselect as
expressions.But it works if for example you use
ng-options="item as item[1] for item in items track by item[0]"
instead ofng-options="item[0] as item[1] for item in items track by item[0]"
See https://jsfiddle.net/b9upojmb/1/