亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

AngularJS遞歸指令實現(xiàn)Tree View效果示例

 更新時間:2016年11月07日 09:56:55   作者:破狼  
這篇文章主要介紹了AngularJS遞歸指令實現(xiàn)Tree View效果,結(jié)合實例形式分析了AngularJS基于遞歸指令實現(xiàn)樹形結(jié)構(gòu)層次數(shù)據(jù)的相關(guān)操作步驟與注意事項,需要的朋友可以參考下

本文實例講述了AngularJS遞歸指令實現(xiàn)Tree View效果的方法。分享給大家供大家參考,具體如下:

在層次數(shù)據(jù)結(jié)構(gòu)展示中,樹是一種極其常見的展現(xiàn)方式。比如系統(tǒng)中目錄結(jié)構(gòu)、企業(yè)組織結(jié)構(gòu)、電子商務(wù)產(chǎn)品分類都是常見的樹形結(jié)構(gòu)數(shù)據(jù)。

這里我們采用Angular的方式來實現(xiàn)這類常見的tree view結(jié)構(gòu)。

首先我們定義數(shù)據(jù)結(jié)構(gòu),采用以children屬性來掛接子節(jié)點方式來展現(xiàn)樹層次結(jié)構(gòu),示例如下:

[
  {
   "id":"1",
   "pid":"0",
   "name":"家用電器",
   "children":[
     {
      "id":"4",
      "pid":"1",
      "name":"大家電"
     }
   ]
  },
  {
   ...
  }
  ...
]

則我們對于ng way的tree view可以實現(xiàn)為:

JavaScript:

angular.module('ng.demo', [])
.directive('treeView',[function(){
   return {
     restrict: 'E',
     templateUrl: '/treeView.html',
     scope: {
       treeData: '=',
       canChecked: '=',
       textField: '@',
       itemClicked: '&',
       itemCheckedChanged: '&',
       itemTemplateUrl: '@'
     },
     controller:['$scope', function($scope){
       $scope.itemExpended = function(item, $event){
         item.$$isExpend = ! item.$$isExpend;
         $event.stopPropagation();
       };
       $scope.getItemIcon = function(item){
         var isLeaf = $scope.isLeaf(item);
         if(isLeaf){
           return 'fa fa-leaf';
         }
         return item.$$isExpend ? 'fa fa-minus': 'fa fa-plus';
       };
       $scope.isLeaf = function(item){
        return !item.children || !item.children.length;
       };
       $scope.warpCallback = function(callback, item, $event){
         ($scope[callback] || angular.noop)({
           $item:item,
           $event:$event
         });
       };
     }]
   };
 }]);

HTML:

樹內(nèi)容主題HTML: /treeView.html

<ul class="tree-view">
    <li ng-repeat="item in treeData" ng-include="'/treeItem.html'" ></li>
</ul>

每個item節(jié)點的HTML:/treeItem.html

<i ng-click="itemExpended(item, $event);" class=""></i>
<input type="checkbox" ng-model="item.$$isChecked" class="check-box" ng-if="canChecked" ng-change="warpCallback('itemCheckedChanged', item, $event)">
<span class='text-field' ng-click="warpCallback('itemClicked', item, $event);"></span>
<ul ng-if="!isLeaf(item)" ng-show="item.$$isExpend">
  <li ng-repeat="item in item.children" ng-include="'/treeItem.html'">
  </li>
</ul>

這里的技巧在于利用ng-include來加載子節(jié)點和數(shù)據(jù),以及利用一個warpCallback方法來轉(zhuǎn)接函數(shù)外部回調(diào)函數(shù),利用angular.noop的空對象模式來避免未注冊的回調(diào)場景。對于View交互的數(shù)據(jù)隔離采用了直接封裝在元數(shù)據(jù)對象的方式,但它們都以$$開頭,如$$isChecked、$$isExpend。在Angular程序中以$$開頭的對象會被認(rèn)為是內(nèi)部的私有變量,在angular.toJson的時候,它們并不會被序列化,所以利用$http發(fā)回服務(wù)端更新的時候,它們并不會影響服務(wù)端傳送的數(shù)據(jù)。同時,在客戶端,我們也能利用對象的這些$$屬性來控制View的狀態(tài),如item.$$isChecked來默認(rèn)選中某一節(jié)點。

我們就可以如下方式來使用這個tree-view:

復(fù)制代碼 代碼如下:
<tree-view tree-data="demo.tree" text-field="name" value-field='id' item-clicked="demo.itemClicked($item)" item-checked-changed="demo.itemCheckedChanged($item)" can-checked="true"></tree-view>

效果如下:

希望本文所述對大家AngularJS程序設(shè)計有所幫助。

相關(guān)文章

  • 使用AngularJS制作一個簡單的RSS閱讀器的教程

    使用AngularJS制作一個簡單的RSS閱讀器的教程

    這篇文章主要介紹了使用Angular.js制作一個簡單的RSS閱讀器的教程,AngularJS是一個非常有人氣的JavaScript庫,文中介紹的制作方法主要使用到了FreedReadR模版,需要的朋友可以參考下
    2015-06-06
  • Angular8引入百度Echarts進行圖表分析的實現(xiàn)代碼

    Angular8引入百度Echarts進行圖表分析的實現(xiàn)代碼

    這篇文章主要介紹了Angular8引入百度Echarts進行圖表分析的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • AngularJS中實現(xiàn)動畫效果的方法

    AngularJS中實現(xiàn)動畫效果的方法

    本文主要介紹AngularJS 動畫,這里對動畫的資料詳細介紹并附有效果圖和代碼實例,有需要的小伙伴參考下
    2016-07-07
  • angular學(xué)習(xí)之動態(tài)創(chuàng)建表單的方法

    angular學(xué)習(xí)之動態(tài)創(chuàng)建表單的方法

    這篇文章主要介紹了angular學(xué)習(xí)之動態(tài)創(chuàng)建表單的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • AngularJS 異步解決實現(xiàn)方法

    AngularJS 異步解決實現(xiàn)方法

    這篇文章主要介紹了AngularJS 異步解決實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • 使用xampp將angular項目運行在web服務(wù)器的教程

    使用xampp將angular項目運行在web服務(wù)器的教程

    這篇文章主要介紹了使用xampp將angular項目運行在web服務(wù)器,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • AngularJS實現(xiàn)網(wǎng)站換膚實例

    AngularJS實現(xiàn)網(wǎng)站換膚實例

    這篇文章主要為大家詳細介紹了AngularJS實現(xiàn)網(wǎng)站換膚的簡單實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Angular2生命周期鉤子函數(shù)的詳細介紹

    Angular2生命周期鉤子函數(shù)的詳細介紹

    這篇文章主要介紹了Angular2生命周期鉤子函數(shù)的詳細介紹,Angular提供組件生命周期鉤子,可以讓我們更好的開發(fā)Angular應(yīng)用,有興趣的可以了解一下
    2017-07-07
  • 妙用Angularjs實現(xiàn)表格按指定列排序

    妙用Angularjs實現(xiàn)表格按指定列排序

    使用AngularJS的過濾器,可以很容易的實現(xiàn)在表格中,點擊某一列標(biāo)題進行排序,實現(xiàn)代碼也很簡單,下面小編給大家分享angularjs實現(xiàn)表格按指定列排序的實現(xiàn)代碼,需要的的朋友參考下吧
    2017-06-06
  • 淺析AngularJS中的生命周期和延遲處理

    淺析AngularJS中的生命周期和延遲處理

    這篇文章主要介紹了淺析AngularJS中的生命周期和延遲處理,是AngularJS中較為核心的深層次內(nèi)容,需要的朋友可以參考下
    2015-06-06

最新評論