zoukankan      html  css  js  c++  java
  • AngularJS select中ngOptions用法详解

     

    AngularJS select中ngOptions用法详解
    一、用法
    ngOption针对不同类型的数据源有不同的用法,主要体现在数组和对象上。
    数组:
    label for value in array
    select as label for value inarray
    labelgroup bygroupforvalueinarray
    selectaslabelgroup bygroupforvalueinarray
    select as label group bygroup for value in array track bytrackexpr
    对象:
    labelfor( key, value) inobject
    selectaslabelfor( key, value) inobject
    labelgroup bygroupfor( key, value) inobject
    selectaslabelgroup bygroupfor( key, value) inobject
    说明:
    array / object: 数据源的类型,有数组和对象两种
    value:迭代过程中,引用数组的项或者对象的属性值
    key:迭代过程中,引用对象的属性名
    label:选项显示的标签,用户可看到的
    select:结果绑定到ngModel中,如果没有指定,则默认绑定value
    group:group by的条件,表示按某条件进行分组
    trackexpr:用于唯一确定数组中的迭代项的表达式
    二、实例
    通用的js代码:
    <script> varMyModule = angular.module("MyModule",[]); MyModule.controller("Ctrl",["$scope", function($scope){ $scope.colors =[ {name:'black', shade:'dark'}, {name:'white', shade:'light'}, {name:'red', shade:'dark'}, {name:'blue', shade:'dark'}, {name:'yellow', shade:'light'} ]; $scope.object ={ dark: "black", light: "red", lai: "red"
    }; }]);
    </script>
    labelfor valuein array
    html:
    <select ng-model="myColor"ng-options="color.name for color in colors"></select>
    效果:
     
    selectas labelfor valuein array
    html:
    <select ng-model="myColor"ng-options="color.shade as color.name for color in colors"></select>
    效果:
    labelgroup by groupfor valuein array
    html:
    <select ng-model="myColor"ng-options="color.name group by color.shade for color in colors"></select>
    效果:
     
    selectas labelgroup by groupfor valuein array
    html:
    <select ng-model="myColor"ng-options="color.name as color.name group by color.shade for color in colors">
    效果:
     
    select as label group by group for value in array track by trackexpr
    html:
    <select ng-model="myColor"ng-options="color.name for color in colors track by color.name">
    效果:
     
    labelfor ( key, value) in object
    html:
    <select ng-model="obj"ng-options="key for (key, value) in object"></select>
    效果:
     
    selectas labelfor ( key, value) in object
    html:
    <select ng-model="obj"ng-options="key as key for (key, value) in object"></select>
    效果:
     
    labelgroup by groupfor ( key, value) in object
    html:
    <select ng-model="obj"ng-options="key group by value for (key, value) in object"></select>
    效果:
     
    select as labelgroup by groupfor ( key, value) in object
    html:
    <select ng-model="obj"ng-options="key as key group by value for (key, value) in object"></select>
    效果:
     
     
     
  • 相关阅读:
    引用传参
    VS2017 用MySQL Connector 链接 MySQL时 getString异常问题
    Matlab学习日记第3天
    Matlab学习日记第2天
    Matlab学习日记第1天
    c#加密解密方法
    DataGridView添加行号
    c#带参数数组链接数据库方法
    2021/5/27
    2021/5/14
  • 原文地址:https://www.cnblogs.com/Jerry-spo/p/5690041.html
Copyright © 2011-2022 走看看