AngularJS导航(li-repeat,创建标题li),DOM

时间:2016-05-14 16:00:37

标签: javascript html angularjs

我通过创建导航来解决AngularJS问题。

我的问题有点复杂。 我只想创建一个像最后一个工作示例的导航。

我的代码有效,但不是创建我想要的DOM。

路线:

.when("/users", {
      templateUrl: "routes/users/template.html",
      controller: "usersCtrl",
      icon: "fa fa-users",
      name: "Users",
      group: "Settings"

    }).when("/plugins", {
      templateUrl: "routes/plugins/template.html",
      controller: "pluginsCtrl",
      icon: "fa fa-plus",
      name: "Plugins",
      group: "Settings"

    }).when("/server", {
      templateUrl: "routes/server/template.html",
      controller: "serverCtrl",
      icon: "fa fa-server",
      name: "Server (HTTP/HTTPS)",
      group: "Experte Settings"

    }).when("/database", {
      templateUrl: "routes/database/template.html",
      controller: "databaseCtrl",
      icon: "fa fa-database",
      name: "Database",
      group: "Experte Settings"

    }).otherwise({
      redirectTo: "/"
    });

导航工厂:

factory('routeNavigation', function($route, $location) {
  
  // placeholder
  var routes = [];
  var groups = [];
  
  // ignore angularjs created routes
  angular.forEach($route.routes, function (route, path){
    if(route.name){
      
      // add nav element
      routes.push({
        path: path,
        name: route.name,
        icon: route.icon,
        group: route.group
      });
            
      // add nav group (when not exists)
      if(groups.indexOf(route.group) === -1){
        groups.push(route.group);  
      }
      
    }
  });
  
  // return
  return {
    routes: routes,
    groups: groups,
    activeRoute: function (route) {
      return route.path === $location.path();
    }
  };
  
});

导航指令:

directive('navigation', function(routeNavigation){
  return {
    restrict: "E",
    replace: true,
    templateUrl: "sidebar.html",
    controller: function($scope){
      $scope.navRoutes = routeNavigation.routes;
      $scope.navGroups = routeNavigation.groups;
      $scope.activeRoute = routeNavigation.activeRoute;
    }
  };
});

Sidebar.html:

<ul class="sidebar-menu">

 
 <li class="header" ng-repeat="group in navGroups">{{group}}</li>
 
 <li class="" ng-repeat="route in navRoutes" ng-class="{active: activeRoute(route)}" > 
  <a href="#!{{route.path}}" ><i class="{{route.icon}}"></i><span>{{route.name}}</span></a>
 </li>

</ul>

问题是标头的li元素具有以下语法:

<li class="header">Header name</li>

一个常规的li元素:

<li class="">
<a href="#!/database" ><i class="fa fa-database"></i><span>Database</span></a>
 </li>

在我的示例中,标题位于元素之前(预期)。 问题就在那里(堆叠)。

工作导航看起来像这样:

<li class="header">Header</li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 1</span></a></li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 2</span></a></li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 3</span></a></li>
<li class="header">Another Header</li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 1</span></a></li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 2</span></a></li>
<li class=""><a href="#!/" ><i class="fa fa-.."></i><span>Example 3</span></a></li>

如何使用angluar创建此内容?

我可以打破angluar ng-repeat并等待finis插入第一个标题,然后重复所有元素与此组(标题),中断,插入第二个标题,继续ng-repeat与第二组?

或者这个问题的最佳解决方案是什么?

非常感谢。

2 个答案:

答案 0 :(得分:0)

尝试使用以下代码可能对您有所帮助

            <li class="" ng-repeat="route in navRoutes" ng-class="{active: activeRoute(route)}" > 
              <a ng-if="route.path" href="#!{{route.path}}" ><i class="{{route.icon}}"></i><span>{{route.name}}</span></a>
              <span ng-if="!route.path">{{route.name}}</span>
            </li>


            var navRoutes = [
                {
                    name:"header1"
                },
                {
                    name:"ex1",
                    path:"/",
                    icon:"act"
                },
                {
                    name:"ex2",
                    path:"/",
                    icon:"act"
                },
                {
                    name:"ex3",
                    path:"/",
                    icon:"act"
                },
                {
                    name:"header2"
                },
                {
                    name:"ex1",
                    path:"/",
                    icon:"act"
                },
                {
                    name:"ex2",
                    path:"/",
                    icon:"act"
                },
                {
                    name:"ex3",
                    path:"/",
                    icon:"act"
                }
            ]

答案 1 :(得分:0)

Soulution:

sidebar.html

&#13;
&#13;
 <li class="" ng-repeat="route in navRoutes" ng-class="{active: activeRoute(route), 'header': !route.path}" > 
  <a ng-if="route.path" href="#!{{route.path}}"><i class="{{route.icon}}"></i><span>{{route.name}}</span></a>
  <span ng-if="!route.path">{{route.name}}</span>
 </li>
&#13;
&#13;
&#13;

导航工厂:

&#13;
&#13;
.factory('routeNavigation', function($route, $location) {
  
  // placeholder
  var routes = [];  
  var groupBefore = null;
  
  // ignore angularjs created routes
  angular.forEach($route.routes, function (route, path){
    if(route.name){
      
      // add group header
      if(groupBefore === null || groupBefore !== route.group){
        groupBefore = route.group;
        routes.push({
          name: route.group
        });
      }
      
      // add nav element
      routes.push({
        path: path,
        name: route.name,
        icon: route.icon,
        group: route.group
      });
      
    }
  });
&#13;
&#13;
&#13;