2016-10-10 48 views
0

我得到了一些幫助來到目前爲止。我只需要進一步實現我的目標。我想通過ng-click動作傳遞的屬性對數據進行分組。我希望在頁面加載或刷新時完成此操作。我如何從下面的代碼實現這一點?如果有更好的方法來實現我的目標,請提出建議。謝謝。嵌套ng重複與groupBy在頁面加載或刷新角度

<!doctype html> 
<html ng-app="Demo" ng-controller="DemoController"> 
<head> 
    <meta charset="utf-8" /> 

    <title> 
     Grouping Nested ngRepeat Lists In AngularJS 
    </title> 
</head> 
<body> 

    <h1> 
     Grouping Nested ngRepeat Lists In AngularJS 
    </h1> 

    <p> 
     Group by: 
     <a ng-click="groupBy('brandName')">Brand Name</a> - 
     <a ng-click="groupBy('hair')">Hair</a> 
    </p> 

    <!-- BEGIN: Outer ngRepeat. --> 
    <div class="col s12" ng-repeat="group in groups" > 
           <ul class="collapsible popout" data-collapsible="accordion"> 
    <li> 
     <div class="collapsible-header"> 
     <a href="#"> 
           <img ng-src="{{group.brandLogo}}" alt="" class="circle responsive-img activator card-profile-image2" onerror="this.src='../../assets/images/backgrounds/cj_avatar.jpg'"> 
          </a> 

     <p>Brand Name: {{ group.label }}</p> 
     </div> 
     <div class="collapsible-body" ng-repeat="camp in group.camps"> 
     <ul class="collection"> 
     <li class="collection-item"> 
     <div class="row"> 
     <div class="col s4 m2 center-align"> 
     {{camp.campID}} 
     </div> 
     <div class="col s4 m3 center-align"> 
      <b>{{camp.campName}}</b> 
     </div> 
     <div class="col s4 m2 center-align"> 
      {{camp.campBudget}} 
     </div> 
     <div class="col s4 m1 center-align"> 
      {{camp.campHits}} 
     </div> 
     <div class="col s4 m2 center-align"> 
      {{camp.campDuration}} 
     </div> 
     <div class="col s4 m2 right-align"> 
      <i class="material-icons ">insert_chart</i> 
      <i class="material-icons">content_copy</i> 
      <i class="material-icons ">delete_forever</i> 
      <i class="material-icons">more_vert</i> 
     </div> 
     </div> 
     </li> 

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

    </ul> 
           </div> 
    <!-- END: Outer ngRepeat. --> 



    <!-- Load jQuery and AngularJS from the CDN. --> 
    <script 
     type="text/javascript" 
     src="//code.jquery.com/jquery-1.9.1.min.js"> 
    </script> 
    <script 
     type="text/javascript" 
     src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.4/angular.min.js"> 
    </script> 

    <!-- Load the app module and its classes. --> 
    <script type="text/javascript"> 
     // Define our AngularJS application module. 
     var demo = angular.module("Demo", []); 
     // -------------------------------------------------- // 
     // -------------------------------------------------- // 
     // I am the main controller for the application. 
     demo.controller(
      "DemoController", 
      function($scope, $timeout) { 
       // -- Define Controller Methods. ------------ // 
       // I sort the given collection on the given property. 
       function sortOn(collection, brandName) { 
        collection.sort(
         function(a, b) { 
          if (a[ brandName ] <= b[ brandName ]) { 
           return(-1); 
          } 
          return(1); 
         } 
        ); 
       } 
       // -- Define Scope Methods. ----------------- // 
       // I group the friends list on the given property. 
       $scope.groupBy = function(attribute) { 
        // First, reset the groups. 
        $scope.groups = []; 
        // Now, sort the collection of friend on the 
        // grouping-property. This just makes it easier 
        // to split the collection. 
        sortOn($scope.camps, attribute); 
        // I determine which group we are currently in. 
        var groupValue = "_INVALID_GROUP_VALUE_"; 
        // As we loop over each friend, add it to the 
        // current group - we'll create a NEW group every 
        // time we come across a new attribute value. 
        for (var i = 0 ; i < $scope.camps.length ; i++) { 
         var camp = $scope.camps[ i ]; 
         // Should we create a new group? 
         if (camp[ attribute ] !== groupValue) { 
          var group = { 
           label: camp[ attribute ], 
           camps: [] 
          }; 
          groupValue = group.label; 
          $scope.groups.push(group); 
         } 
         // Add the friend to the currently active 
         // grouping. 
         group.camps.push(camp); 
        } 
       }; 
       // -- Define Scope Variables. --------------- // 
       // I am the raw collection of friends. 
       $scope.camps = [ 
        {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:032145, campName:"Y3 Twi Kor", campBudget:500, campHits:"7k", campDuration:"15 Days", campDesc:""}, 
        {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:639885, campName:"X Bundle", campBudget:900, campHits:"6.2k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:857745, campName:"One Ghana", campBudget:1000, campHits:"9k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:795554, campName:"Free Bonto", campBudget:1500, campHits:"8.1k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:722957, campName:"Anajo Y3 D3", campBudget:650, campHits:"1.2k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:769855, campName:"Y3n Ko Nkoa", campBudget:780, campHits:"6.4k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:742896, campName:"Drink for life", campBudget:7000, campHits:"3.8k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:087759, campName:"Pure as Spirit", campBudget:910, campHits:"1.7k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:085997, campName:" Nourish your thirst", campBudget:1200, campHits:"9.2k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:398745, campName:"Fountain of life", campBudget:9800, campHits:"8.5k", campDuration:"15 Days", campDesc:""}, 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:297556, campName:" Spring of Youth", campBudget:250, campHits:"4k", campDuration:"15 Days", campDesc:""} 

       ]; 
       // I am the grouped collection. Each one of these 
       // will contain a sub-collection of friends. 
       $scope.groups = []; 
      } 
     ); 
    </script> 

</body> 
</html> 

回答

0

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 
<html ng-app="Demo" ng-controller="DemoController"> 
 
<head> 
 
    <meta charset="utf-8" /> 
 

 
    <title> 
 
     Grouping Nested ngRepeat Lists In AngularJS 
 
    </title> 
 
</head> 
 
<body> 
 

 
    <h1> 
 
     Grouping Nested ngRepeat Lists In AngularJS 
 
    </h1> 
 

 
    <p> 
 
     Group by: 
 
     <a ng-click="groupBy('brandName')">Brand Name</a> - 
 
     <a ng-click="groupBy('hair')">Hair</a> 
 
    </p> 
 

 
    <!-- BEGIN: Outer ngRepeat. --> 
 
    <div class="col s12" ng-repeat="group in groups" > 
 
           <ul class="collapsible popout" data-collapsible="accordion"> 
 
    <li> 
 
     <div class="collapsible-header"> 
 
     <a href="#"> 
 
           <img ng-src="{{group.brandLogo}}" alt="" class="circle responsive-img activator card-profile-image2" onerror="this.src='../../assets/images/backgrounds/cj_avatar.jpg'"> 
 
          </a> 
 

 
     <p>Brand Name: {{ group.label }}</p> 
 
     </div> 
 
     <div class="collapsible-body" ng-repeat="camp in group.camps"> 
 
     <ul class="collection"> 
 
     <li class="collection-item"> 
 
     <div class="row"> 
 
     <div class="col s4 m2 center-align"> 
 
     {{camp.campID}} 
 
     </div> 
 
     <div class="col s4 m3 center-align"> 
 
      <b>{{camp.campName}}</b> 
 
     </div> 
 
     <div class="col s4 m2 center-align"> 
 
      {{camp.campBudget}} 
 
     </div> 
 
     <div class="col s4 m1 center-align"> 
 
      {{camp.campHits}} 
 
     </div> 
 
     <div class="col s4 m2 center-align"> 
 
      {{camp.campDuration}} 
 
     </div> 
 
     <div class="col s4 m2 right-align"> 
 
      <i class="material-icons ">insert_chart</i> 
 
      <i class="material-icons">content_copy</i> 
 
      <i class="material-icons ">delete_forever</i> 
 
      <i class="material-icons">more_vert</i> 
 
     </div> 
 
     </div> 
 
     </li> 
 

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

 
    </ul> 
 
           </div> 
 
    <!-- END: Outer ngRepeat. --> 
 

 

 

 
    <!-- Load jQuery and AngularJS from the CDN. --> 
 
    <script 
 
     type="text/javascript" 
 
     src="//code.jquery.com/jquery-1.9.1.min.js"> 
 
    </script> 
 
    <script 
 
     type="text/javascript" 
 
     src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.4/angular.min.js"> 
 
    </script> 
 

 
    <!-- Load the app module and its classes. --> 
 
    <script type="text/javascript"> 
 
     // Define our AngularJS application module. 
 
     var demo = angular.module("Demo", []); 
 
     // -------------------------------------------------- // 
 
     // -------------------------------------------------- // 
 
     // I am the main controller for the application. 
 
     demo.controller(
 
      "DemoController", 
 
      function($scope, $timeout) { 
 
       // -- Define Controller Methods. ------------ // 
 
       // I sort the given collection on the given property. 
 
       function sortOn(collection, brandName) { 
 
        collection.sort(
 
         function(a, b) { 
 
          if (a[ brandName ] <= b[ brandName ]) { 
 
           return(-1); 
 
          } 
 
          return(1); 
 
         } 
 
        ); 
 
       } 
 
       // -- Define Scope Methods. ----------------- // 
 
       // I group the friends list on the given property. 
 
       
 
       $scope.groupBy = function(attribute) { 
 
        // First, reset the groups. 
 
        $scope.groups = []; 
 
        // Now, sort the collection of friend on the 
 
        // grouping-property. This just makes it easier 
 
        // to split the collection. 
 
        sortOn($scope.camps, attribute); 
 
        // I determine which group we are currently in. 
 
        var groupValue = "_INVALID_GROUP_VALUE_"; 
 
        // As we loop over each friend, add it to the 
 
        // current group - we'll create a NEW group ever 
 

 
        // time we come across a new attribute value. 
 
        for (var i = 0 ; i < $scope.camps.length ; i++) { 
 
         var camp = $scope.camps[ i ]; 
 
         // Should we create a new group? 
 
         if (camp[ attribute ] !== groupValue) { 
 
          var group = { 
 
           label: camp[ attribute ], 
 
           camps: [] 
 
          }; 
 
          groupValue = group.label; 
 
          $scope.groups.push(group); 
 
         } 
 
         // Add the friend to the currently active 
 
         // grouping. 
 
         group.camps.push(camp); 
 
        } 
 
       }; 
 
       
 
       // -- Define Scope Variables. --------------- // 
 
       // I am the raw collection of friends. 
 
       $scope.camps = [ 
 
        {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:032145, campName:"Y3 Twi Kor", campBudget:500, campHits:"7k", campDuration:"15 Days", campDesc:""}, 
 
        {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:639885, campName:"X Bundle", campBudget:900, campHits:"6.2k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/vodafone.jpg", brandName:"Vodafone", campID:857745, campName:"One Ghana", campBudget:1000, campHits:"9k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:795554, campName:"Free Bonto", campBudget:1500, campHits:"8.1k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:722957, campName:"Anajo Y3 D3", campBudget:650, campHits:"1.2k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/mtn.jpg", brandName:"MTN", campID:769855, campName:"Y3n Ko Nkoa", campBudget:780, campHits:"6.4k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:742896, campName:"Drink for life", campBudget:7000, campHits:"3.8k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:087759, campName:"Pure as Spirit", campBudget:910, campHits:"1.7k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:085997, campName:" Nourish your thirst", campBudget:1200, campHits:"9.2k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:398745, campName:"Fountain of life", campBudget:9800, campHits:"8.5k", campDuration:"15 Days", campDesc:""}, 
 
    {brandLogo:"../../assets/images/brands/voltic.jpg", brandName:"Voltic", campID:297556, campName:" Spring of Youth", campBudget:250, campHits:"4k", campDuration:"15 Days", campDesc:""} 
 

 
       ]; 
 
       // I am the grouped collection. Each one of these 
 
       // will contain a sub-collection of friends. 
 
       $scope.groups = []; 
 
       $scope.groupBy('brandName'); 
 
      } 
 
     ); 
 
    </script> 
 

 
</body> 
 
</html>

這是很簡單的實際。你只需要調用你的

$scope.groupBy('brandName') 

在你的控制器的某個地方。

另一種更簡潔的方法是(如果你打算按比例),使用resolve方法ngRouteruiRouter解決您的數據和加載頁面的預格式化它。

+0

謝謝NikJohn。這很簡單。關於解決方法位我該如何應用它? – Selase

+0

再一次,它非常簡單。您需要先使用'ngRouter'或'uiRouter'設置路由。你可以關注[this](http://odetocode.com/blogs/scott/archive/2014/05/20/using-resolve-in-angularjs-routes.aspx)教程。一旦完成,你可以在狀態/路由定義中定義一個'resolve'方法,就像[so]一樣(http://odetocode.com/blogs/scott/archive/2014/05/20/using-resolve-in-angularjs- routes.aspx) – nikjohn

0

您可以使用過濾功能來過濾結果讓說,你正在試圖形成從過濾結果的表,你可以做這樣的

//example to group by propertyname 
    <table ng-controller="myCtrl" border="1"> 
    <tr ng-repeat="x in camps | groupBy:'brandName' }"> 
    <td>{{x.campName}}</td> 
    <td>{{x.campBudget}}</td> 
    </tr> 

    //example to filter by a propertyValue 
    <table ng-controller="myCtrl" border="1"> 
    <tr ng-repeat="x in camps | filter:{ brandName: 'yourbrandname' }"> 
    <td>{{x.campName}}</td> 
    <td>{{x.campBudget}}</td> 
    </tr> 
    </table> 

在這裏,我已經使用硬編碼值,但你可以使用以角度數據綁定來動態更改品牌名稱。

+0

你正在想我的線:http://plnkr.co/edit/YSpSkASc65D8z3NNnP2D?p=preview – Zach