javascript - Angularjs ngrepeat和ngoptions, "as" "for"关键字是什么?

标签 javascript angularjs

 $scope.items = [{
   id: 1,
   label: 'aLabel',
   subItem: { name: 'aSubItem' }
 }, {
   id: 2,
   label: 'bLabel',
   subItem: { name: 'bSubItem' }
 }];

根据上面的列表,以下是我通常使用的:

<select ng-options="item in items" ng-model="selected"></select>

非常简单,例如,我可以使用 item.xxx 访问该值

但是下面的语法是什么:

<select ng-options="item as item.label for item in items" ng-model="selected"></select>

我完全模糊了,asfor关键字的目的是什么?我实在找不到解释这一点的文档,请帮忙。

PS: 原始语法是 <select ng-options="item as item.label for item in items track by item.id" ng-model="selected"></select>但我删除了 track by ,因为我通过阅读文档了解了这一点。

最佳答案

这是 <select> 的选项列表应引用填充选项。

 $scope.items = [{
   id: 1,
   label: 'aLabel',
   subItem: { name: 'aSubItem' }
 }, {
   id: 2,
   label: 'bLabel',
   subItem: { name: 'bSubItem' }
 }];

当你写ng-options="item as item.label for item in items"时,您正在迭代 items ,其中每个项目都分配给 item通过使用item in items .

因此,对于第一次迭代,item的值将是:

{
   id: 1,
   label: 'aLabel',
   subItem: { name: 'aSubItem' }
 }

请注意item在本例中是一个对象

<option>不关心您如何为其获取数据,它只关心它需要显示的内容以及在选择它时分配什么值。所以,我们告诉ng-options使用for需要 item作为输入并生成对应的<option>元素。

现在在选择选项中,假设您希望输入为 id 。但是嘿,谁知道你的 id 是什么意思? ,为了人类可读,您需要显示一些有意义的消息来识别它,即 label在这种情况下。

因此,您将仅使用它的id,而不是使用整个对象。使用label时识别它(下拉列表中显示的文本)。 现在您的代码更改为:

ng-options="item.id as item.label for item in items"

所以最终生成的 HTML 变成这样:

<select>
  <option value="1">aLabel</option>
  <option value="2">bLabel</option>
</select>

关于javascript - Angularjs ngrepeat和ngoptions, "as" "for"关键字是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39409371/

相关文章:

javascript - 不把它变成一个字符串

javascript - 使用 localStorage 跨多个页面存储变量?

javascript - 如何评估 ng-Class 指令中的作用域对象?

javascript - 在 ng-repeat 中调用函数

javascript - Drupal 7 + smoothdivscroll?

javascript - 提供者无法访问 redux store

javascript - 仅当文本字段中有值时,如何将自定义过滤器应用于 ng-repeat?

javascript - 没有过滤器的 AngularUI Datepicker,发生了什么?

javascript - 将 Dropzone file.fullPath 发送到 Rails Controller

angularjs - 如何在具有隔离范围的指令上使用 ng-click?