如何将数组数据绑定到angularjs中的下拉列表?

时间:2017-05-25 06:31:36

标签: javascript angularjs

您好我正在开发angularjs中的Web应用程序。我正在尝试将数据绑定到drodpown。我正在进行ajax调用以从服务器获取数据。我收到错误无法读取未定义的属性'长度'。我正在提出要求。这是我的api。 http://192.168.0.213:1234/api/Customer/Nationalities

上面的api将返回

{"status":"Success","msg":"Success","code":"200","data":[{"ID":1,"Nationality":"indian"},{"ID":2,"Nationality":"england"}]}

我使用js绑定如下。

  var url = cfg.Baseurl;
            var nationality = new Array();
            $http.get(url + 'api' + '/Customer/' + 'Nationalities').success(function (data) {
                $.map(data.data.Nationality, function (item) {
                    nationality.push(item);
                    console.log(item);
                });
                $scope.nationalityList = nationality;
            }).error(function (status) {
            });

这是我的HTML代码。

   <select ng-model="user.nationality" id="brand" ng-options="user.nationality for user in nationalityList" required>
                            <option value="" label="Select">Select</option>
                        </select>

我最终无法读取未定义错误的属性“长度”。任何帮助,将不胜感激。谢谢。

5 个答案:

答案 0 :(得分:1)

以下是演示链接Jsfiddle demo

JS代码

  var app = angular.module('myApp', []);

  app.controller('ctrl', function($scope) {
    $scope.nationalityList = {
      "status": "Success",
      "msg": "Success",
      "code": "200",
      "data": [{
        "ID": 1,
        "Nationality": "indian"
      }, {
        "ID": 2,
        "Nationality": "england"
      }]
    };
  });

** HTML **

  <div ng-app='myApp'>

    <div ng-controller='ctrl'>
      <select ng-model="user.nationality" id="brand" ng-options="user.Nationality for user in nationalityList.data" required>
        <option value="" label="Select">Select</option>
      </select>
      <span>nationality = {{user.nationality}}</span>
    </div>
  </div>

希望这会帮助你

答案 1 :(得分:1)

在这种情况下,没有必要进行映射,它只分配数组的值

var url = cfg.Baseurl;
var nationality = [];
$http.get(url + 'api' + '/Customer/' + 'Nationalities')
.success(function (data) {
    if(data.data) {
        // Here the value is assigned
        $scope.nationalityList = data.data;
    }
}).error(function (status) { });

你的html必须像这样

<select
    ng-model="selectedNationality"
    id="brand"
    ng-options="item.Nationality for item in nationalityList" 
    required>
    <option value="" label="Select">Select</option>
</select>
<!-- Showing selected option -->
<p ng-if="selectedNationality">Selected option: {{selectedNationality}}<p/>

了解更多信息https://docs.angularjs.org/api/ng/directive/ngOptions

答案 2 :(得分:1)

由于$scope.nationalityList未初始化,因此在呈现视图时未定义Cannot read property 'length' of undefined error.。因此错误 window.onload = function() { document.getElementById("formId").submit(); };

只需将变量初始化为空数组即可解决此错误。

答案 3 :(得分:0)

希望这会有所帮助:

使用$scope.anArray =[];

将数据绑定到$http响应中的数组。

Angular js How to populate dropdown with JSON without ng-options

实施例: http://plnkr.co/edit/evQJAKvMnl4btz4BZeuP?p=preview

我确定您使用的是Json对象响应。

答案 4 :(得分:0)

$.map(data.data.Nationality, function (item) {
                    nationality.push(item);
                    console.log(item);
                });

data.data.Nationality无效,因为data.data是一个数组而不是对象 所以,nationality = data.data 会工作得很好