如何使用 AngularJS 从 JSON 提要填充选择下拉列表?

IT技术 javascript angularjs drop-down-menu
2021-03-16 11:51:04

我一直在努力寻找示例,但根本找不到任何东西。我唯一知道的是我可以使用 http module来获取我的数据。这是我目前正在做的事情,但它是用 Knockout 编码的。有人能给我一些关于如何使用 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>
3个回答

正确的做法是使用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;
    });
});

您还需要确保 angular 在您的 html 上运行并且您的module已加载。

<html ng-app="test">
    <body ng-controller="DemoCtrl">
    ....
    </body>
</html>
Martin,这将立即执行 $http()。是否可以仅在发生特定事件时才填充下拉列表 - 例如用户选择多个单选按钮之一?如果是,在哪里可以找到工作代码示例?换句话说,如何实现延迟加载、按需下拉列表(通过 AJAX)?
2021-04-28 11:51:04
有人可以发布预期的 JSON 吗?TIA
2021-05-12 11:51:04
这让我绊倒了;所以我想我会在这里发表评论。如果未指定 ng-model,则 ng-options 似乎没有影响。否则,+1;谢谢你的回答。
2021-05-13 11:51:04
<select name="selectedFacilityId" ng-model="selectedFacilityId">
         <option ng-repeat="facility in facilities" value="{{facility.id}}">{{facility.name}}</option>
     </select>  

这是有关如何使用它的示例。

我认为它应该是 ng-repeat 而不是 ng:repeat :)
2021-04-26 11:51:04
请注意,这比公认的答案更占用内存:docs.angularjs.org/api/ng/directive/ngOptions
2021-05-01 11:51:04

在我的 Angular Bootstrap 下拉菜单中,我使用 ng-init 初始化了 JSON 数组(vm.zoneDropdown)(您也可以在指令模板中使用 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>