我怎样才能从填充用AngularJS一个JSON饲料选择下拉列表?(How can I popula

2019-08-18 03:30发布

我一直在寻找很难的例子,但无法找到任何东西都。 我唯一知道的是,我可以使用HTTP模块让我的数据。 这是我目前在做什么,但它与淘汰赛编码。 有人可以给我,我怎么能重新编写使用AngularJS此功能一些建议吗?

HTML

<select id="testAccounts" 
   data-bind="options: testAccounts, optionsValue: 'Id', optionsText: 'Name', optionsCaption: 'Select Account', value: selectedTestAccount">
</select>

使用Javascript

<script type='text/javascript'>
    $(document).ready(function () {

        var townSelect = function () {
        var self = this;
        self.selectedTestAccount = ko.observable();
        self.testAccounts = ko.observableArray();
        var townViewModel = new townSelect();
        ko.applyBindings(townViewModel);

        $.ajax({
            url: '/Admin/GetTestAccounts',
            data: { applicationId: 3 },
            type: 'GET',
            success: function (data) {
                townViewModel.testAccounts(data);
            }
        });
    });
</script>

Answer 1:

这样做的正确方法是使用ng-options指令 。 该HTML是这样的。

<select ng-model="selectedTestAccount" 
        ng-options="item.Id as item.Name for item in testAccounts">
    <option value="">Select Account</option>
</select>

JavaScript的:

angular.module('test', []).controller('DemoCtrl', function ($scope, $http) {
    $scope.selectedTestAccount = null;
    $scope.testAccounts = [];

    $http({
            method: 'GET',
            url: '/Admin/GetTestAccounts',
            data: { applicationId: 3 }
        }).success(function (result) {
        $scope.testAccounts = result;
    });
});

您还需要确保的角度是在HTML运行,你的模块被加载。

<html ng-app="test">
    <body ng-controller="DemoCtrl">
    ....
    </body>
</html>


Answer 2:

<select name="selectedFacilityId" ng-model="selectedFacilityId">
         <option ng-repeat="facility in facilities" value="{{facility.id}}">{{facility.name}}</option>
     </select>  

这是一个关于如何使用它的一个例子。



Answer 3:

在我的角度引导下拉菜单我初始化JSON阵列(vm.zoneDropdown)与NG-的init(你也可以让指令模板中NG-INIT)和我通过一个自定义src属性阵列

<custom-dropdown control-id="zone" label="Zona" model="vm.form.zone" src="vm.zoneDropdown"
                         ng-init="vm.getZoneDropdownSrc()" is-required="true" form="farmaciaForm" css-class="custom-dropdown col-md-3"></custom-dropdown>

内部控制器:

vm.zoneDropdown = [];
vm.getZoneDropdownSrc = function () {
    vm.zoneDropdown = $customService.getZone();
}

而customDropdown指令模板内(注意,这是唯一一个自举下拉的一部分):

<ul class="uib-dropdown-menu" role="menu" aria-labelledby="btn-append-to-body">
    <li role="menuitem" ng-repeat="dropdownItem in vm.src" ng-click="vm.setValue(dropdownItem)">
        <a ng-click="vm.preventDefault($event)" href="##">{{dropdownItem.text}}</a>
    </li>
</ul>


文章来源: How can I populate a select dropdown list from a JSON feed with AngularJS?