zoukankan      html  css  js  c++  java
  • ng-option小解

    ng-option 有数组,对象两种情况,但目前只接触过数组

    数组:

    label for value in array

    分为一般数组和对象数组

    一般数组:

    <select ng-model="myAddress" ng-options="item for item in address"></select>

    $scope.address= ["北京", "天津", "河北"];

    发现第一项为空

    dom树如下:

    解析: 1.当未设置初始值时,初始值及option列表第一项为空,默认第一项被选 2.value等于label

    设置初始值方法:

    1.$scope.myAddress= $scope.address[0];

    注: 初始值必须得是数组中的某一项,否则无效

    则变为:

    2.新增option

    <select ng-model="myAddress" ng-options="item for item in address">
      <option value="" disabled="">请选择地址</option>
    </select>

    (值得一提的是这种方法只能新增一个option,多写的不会出现)

    变为:

    disable的option会变为不可选的灰色,此种方法应用面更广

    对象数组:

    <select ng-model="myColor1" ng-options="color.name for color in colors"></select>

    $scope.colors = [
      {name:'black', shade:'dark'},
      {name:'white', shade:'light', notAnOption: true},
      {name:'red', shade:'dark'},
      {name:'blue', shade:'dark', notAnOption: true},
      {name:'yellow', shade:'light', notAnOption: false}];

    dom树如下:

    解析: 写法与一般数组不同,value为label所属的对象

    ---------------------------------------------------------------------------------------------------------------------------------------------------------

    label group by group for value in array(选项分组)

    <select ng-model="myColor2" ng-options="color.name group by color.shade for color in colors"></select>

                               label                    分组依据属性     

    $scope.colors = [
    {name:'black', shade:'dark'},
    {name:'white', shade:'light', notAnOption: true},
    {name:'red', shade:'dark'},
    {name:'blue', shade:'dark', notAnOption: true},
    {name:'yellow', shade:'light', notAnOption: false}
    ];

    可见按照shade属性进行了分组

    ----------------------------------------------------------------------------------------------------------------------------------------------------------

    label disable when disable for value in array(将部分option设为disable)

    <select ng-model="myColor3" ng-options="color.name disable when color.notAnOption for color in colors"></select>

                            label                          disable依据属性

    $scope.colors = [
    {name:'black', shade:'dark'},
    {name:'white', shade:'light', notAnOption: true},
    {name:'red', shade:'dark'},
    {name:'blue', shade:'dark', notAnOption: true},
    {name:'yellow', shade:'light', notAnOption: false}
    ];

    可以看出当notAnOption未false时不可点击

    --------------------------------------------------------------------------------------------------------------------------------------------

    select as label for value in array(设置value)

    <select ng-model="myColor4" ng-options="color.shade as color.name for color in colors"></select>

                           value             label

    可见shade成了value,name成了label

    -------------------------------------------------------------------------------------------------------------------------------------------------

  • 相关阅读:
    CentOS7使用集群同步脚本对文件同步分发
    CentOS7安装jdk1.8
    CentOS7+CDH5.12.1集群搭建
    nginx通配符
    Nginx反向代理及配置
    一些好玩有用的书签
    linux操作小技巧锦集
    系统压测结果对比:tomcat/thinkphp/swoole/php-fpm/apache
    python修改linux日志(logtamper.py)
    【原创】给定随机数的取值范围(最小值、最大值),且要求多次取得的随机数最后的结果有一个固定的平均值
  • 原文地址:https://www.cnblogs.com/yanze/p/6071332.html
Copyright © 2011-2022 走看看