首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AngularJS显示分层数据

AngularJS显示分层数据
EN

Stack Overflow用户
提问于 2015-07-22 03:33:04
回答 1查看 1.6K关注 0票数 4

我试图在分层视图中显示数据列表。我的数据如下所示:

代码语言:javascript
复制
items:[
  {
    "model_id": "1",
    "model_type_id": "1",
    "name": "Parent 1",
    "model_parent_id": ""
  },
  {
    "model_id": "2",
    "model_type_id": "1",
    "name": "Parent 2",
    "model_parent_id": ""
  },
  {
    "model_id": "3",
    "model_type_id": "2",
    "name": "Child 1",
    "model_parent_id": "1"
  },
  {
    "model_id": "4",
    "model_type_id": "2",
    "name": "Child 2",
    "model_parent_id": "2"
  }
]

我的控制器看起来像:

代码语言:javascript
复制
myApp.controller('ModelController', ['$scope', 'ModelFactory',
    function ($scope, ModelFactory) {

        $scope.init = function (id) {
            $scope.brandId = id;
            getModels($scope.brandId);
        };

        function getModels(brandId) {

            ModelFactory.GetModels(brandId)
                .success(function (mdls) {
                    $scope.models = mdls;
                    console.log($scope.mdls);
                })
                .error(function (error) {
                    $scope.status = 'Unable to load model data: ' + error.message;
                    console.log($scope.status);
                });
        };
    }
]);

我的HTML看起来像:

代码语言:javascript
复制
<div ng-controller="ModelController" ng-init="init(brand.ID)">
    <ul ng-sortable class="block__list block__list_words">
        <li ng-repeat="model in models | filter: {model_type_id:1} ">{{model.model_name}} - {{model.model_id}}

            <div ng-controller="ModelController" ng-init="init(brand.ID)">
                <ul ng-sortable class="block__list block__list_words">
                    <li ng-repeat="m in models | filter: {model_type_id:2} | filter:{model_parent_id:model.model_id}">
                        {{m.model_name}} - {{m.model_parent_id}}
                    </li>
                </ul>
            </div>

        </li>
    </ul>
</div>

在我试图用外部控制器对内部控制器进行过滤的地方,过滤器没有工作。我要把两个孩子都显示在父母下面。我怎样才能得到它,这样就可以显示父文件,并且只有子程序显示在其子model_parent_id等于父程序的model_id的位置?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-22 05:17:43

虽然我不确定是否有一种使用过滤器实现这一目标的方法,但显示嵌套数据的通常方法是重新组织数据结构,以反映您想要显示的内容。

代码语言:javascript
复制
items:[
  {
    "model_id": "1",
    "model_type_id": "1",
    "name": "Parent 1",
    "children": [{
      "model_id": "3",
      "model_type_id": "2",
      "name": "Child 1"
    }]
  },
  {
    "model_id": "2",
    "model_type_id": "1",
    "name": "Parent 2",
    "children": [{
      "model_id": "3",
      "model_type_id": "2",
      "name": "Child 2"
    }]
  }
]

,然后使用嵌套ng-重复显示它们。

代码语言:javascript
复制
<ul>
  <li ng-repeat="parent in items">
    {{parent.name}} - {{parent.model_id}}
    <ul>
      <li ng-repeat="child in parent.children">
        {{child.name}} - {{child.model_id}}
      </li>
    </ul>
  </li>
</ul>

注意:没有必要使用嵌套控制器,只需要在顶层使用一个就足够了。如果需要递归地使用某些共享逻辑,请使用自定义指令替换li。

若要重新组织数据,可以在服务器端或客户端进行。以下说明了如何在客户端进行操作,因为我们可能没有更改服务器端API的权限。

代码语言:javascript
复制
$scope.data = [];
angular.forEach(items, function(item) {
    if (item.model_parent_id == "") {
        $scope.data.push(item);
    }  
});

// add all parents first in case some children comes before parent
angular.forEach(items, function(item) {
    if (item.model_parent_id == "") continue;

    // search for parent
    angular.forEach($scope.data, function(parent) {
        if (parent.model_id == item.model_parent_id) {
            if (!parent.children) parent.children = [];
            parent.children.push(item);
        }
    }
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31553374

复制
相关文章

相似问题

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