目前我正在尝试使用ng-options指令加载选择框。
但是我无法更改已创建选项的值,它只是从0到3,而我希望这些值与" eigenschap_id"相同。我通过了。
所以它的值应该是23-26而不是0-3
哪里出错?
以下是我正在使用的代码。
控制器:
$scope.eigenschappen.game = categories.Game;
Jsonstring / object:
[{"cat_id":6,"cat_name":"Game","eigenschap_name":"RPG","eigenschap_id":23},{"cat_id":6,"cat_name":"Game","eigenschap_name":"Strategie","eigenschap_id":24},{"cat_id":6,"cat_name":"Game","eigenschap_name":"Avontuur","eigenschap_id":25},{"cat_id":6,"cat_name":"Game","eigenschap_name":"Simulatie","eigenschap_id":26}]
Html View
<select data-ng-options="i.eigenschap_id as i.eigenschap_name for i in eigenschappen.game" ng-model="chosen"></select>
生成的html
<select ng-model="chosen" data-ng-options="i.eigenschap_id as i.eigenschap_name for i in eigenschappen.game" class="ng-pristine ng-valid">
<option value="?" selected="selected"></option>
<option value="0">RPG</option>
<option value="1">Strategie</option>
<option value="2">Avontuur</option>
<option value="3">Simulatie</option>
</select>
答案 0 :(得分:8)
当Angular生成HTML选择选项时,(每个选项元素的)value属性可能不是您所期望的......它设置如下: 。当使用数组作为数据源时,该值设置为数组索引 。当使用object作为数据源时,该值设置为键/属性名称
当用户选择其中一个选项时,Angular使用索引(或键)查找数组(或对象)中的值 - 该查找值是模型设置的值。 (因此,模型未设置为您在HTML中看到的值!这会导致很多混淆。)
例如,对于数组数据源,Angular会将模型值设置为所选选项值参数指定的索引处的数组中的值。如果您的数据源数组是[2013,2014,2015],则生成的HTML将具有选项元素的值0,1,2。如果选择第二个项目,Angular会在数组[1]中查找值2014,然后将模型设置为
资料来源:Mark RajCok评论http://docs.angularjs.org/api/ng.directive:select