首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >异步数据获取和角度库

异步数据获取和角度库
EN

Stack Overflow用户
提问于 2014-04-11 05:41:19
回答 1查看 348关注 0票数 0

“我有以下问题:我想从异步rest调用中获取json,并在Angular库(在我的例子中是angular-ui-tree和angular-charts)的一些现有指令中使用它。

这是一个简单的例子,用angular-ui-tree来解释我的问题。服务:

代码语言:javascript
复制
var mod = angular.module("user.services");
mod.factory("userService", ["$http",  function ($http) {

    return {
        getUserMenu: function () {
        //call rest
            return $http.get('/user/menu').then(function (response) {
                    return response.data;
            });
        }
    };
}]);

控制器:

代码语言:javascript
复制
var mod = angular.module("admin.controllers");
$scope.menu = [];
userService.getUserMenu().then(function(menuResp){
     $scope.menu = menuResp;
};
$scope.showbody = true;
$scope.selectedItem = {}; 
$scope.options = {};
...

页面(它只是一个片段):

代码语言:javascript
复制
<div ng-controller="MenuListCtrl">
<script type="text/ng-template" id="items_renderer.html">
   <div ui-tree-handle>... </div>
   <ol ui-tree-nodes="options" ng-model="item.items">
    <li ng-repeat="item in item.submenu" ui-tree-node ng-include="'items_renderer.html'"></li>
    </ol>
</script>
<div ui-tree="options">
<ol ui-tree-nodes ng-model="list" >
 <li ng-repeat="item in menu" ui-tree-node ng-include="'items_renderer.html'"></li>
</ol>
</div>

当我打开我的页面时,树被正确地呈现,但我在控制台中有一个错误。在Angular-ui的情况下,错误是“无法读取未定义的属性'0‘”。我认为这是因为当控制器加载菜单变量时没有设置。

也许这种方式是错误的。我认为解决方案是在数据加载后渲染angular-ui-tree片段。如下所示:

代码语言:javascript
复制
var mod = angular.module("tnp.admin.controllers");
userService.getUserMenu().then(function(menuResp){
//render tree template with menuResp data or append in my fragment the angular-ui-tree directive with menuResp data
};

我在其他库中遇到了这个问题。错误是不同的,但我认为基本问题是相同的。有没有人能帮我?我如何渲染我的片段这个菜单数据?谢谢!

EN

回答 1

Stack Overflow用户

发布于 2014-04-11 06:17:10

我不明白为什么需要在您的服务中声明menu。在调用服务进行填充之前,您应该确保在控制器中将$scope.menu设置为空数组。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22999567

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档