AngularJS遞歸指令實(shí)現(xiàn)Tree View效果示例
本文實(shí)例講述了AngularJS遞歸指令實(shí)現(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的方式來實(shí)現(xiàn)這類常見的tree view結(jié)構(gòu)。
首先我們定義數(shù)據(jù)結(jié)構(gòu),采用以children屬性來掛接子節(jié)點(diǎn)方式來展現(xiàn)樹層次結(jié)構(gòu),示例如下:
[ { "id":"1", "pid":"0", "name":"家用電器", "children":[ { "id":"4", "pid":"1", "name":"大家電" } ] }, { ... } ... ]
則我們對于ng way的tree view可以實(shí)現(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>
每個(gè)item節(jié)點(diǎn)的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é)點(diǎn)和數(shù)據(jù),以及利用一個(gè)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的時(shí)候,它們并不會被序列化,所以利用$http發(fā)回服務(wù)端更新的時(shí)候,它們并不會影響服務(wù)端傳送的數(shù)據(jù)。同時(shí),在客戶端,我們也能利用對象的這些$$屬性來控制View的狀態(tài),如item.$$isChecked來默認(rèn)選中某一節(jié)點(diǎn)。
我們就可以如下方式來使用這個(gè)tree-view:
效果如下:
希望本文所述對大家AngularJS程序設(shè)計(jì)有所幫助。
- 利用java+mysql遞歸實(shí)現(xiàn)拼接樹形JSON列表的方法示例
- Javascript 實(shí)現(xiàn)匿名遞歸的實(shí)例代碼
- JS基于遞歸算法實(shí)現(xiàn)1,2,3,4,5,6,7,8,9倒序放入數(shù)組中的方法
- Vue.js 遞歸組件實(shí)現(xiàn)樹形菜單(實(shí)例分享)
- JS基于遞歸實(shí)現(xiàn)倒計(jì)時(shí)效果的方法
- java、js中實(shí)現(xiàn)無限層級的樹形結(jié)構(gòu)方法(類似遞歸)
- javascript實(shí)現(xiàn)網(wǎng)頁子頁面遍歷回調(diào)的方法(涉及 window.frames、遞歸函數(shù)、函數(shù)上下文)
- 一個(gè)JavaScript遞歸實(shí)現(xiàn)反轉(zhuǎn)數(shù)組字符串的實(shí)例
- JavaScript中遞歸實(shí)現(xiàn)的方法及其區(qū)別
相關(guān)文章
使用AngularJS制作一個(gè)簡單的RSS閱讀器的教程
這篇文章主要介紹了使用Angular.js制作一個(gè)簡單的RSS閱讀器的教程,AngularJS是一個(gè)非常有人氣的JavaScript庫,文中介紹的制作方法主要使用到了FreedReadR模版,需要的朋友可以參考下2015-06-06Angular8引入百度Echarts進(jìn)行圖表分析的實(shí)現(xiàn)代碼
這篇文章主要介紹了Angular8引入百度Echarts進(jìn)行圖表分析的實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11AngularJS中實(shí)現(xiàn)動(dòng)畫效果的方法
本文主要介紹AngularJS 動(dòng)畫,這里對動(dòng)畫的資料詳細(xì)介紹并附有效果圖和代碼實(shí)例,有需要的小伙伴參考下2016-07-07angular學(xué)習(xí)之動(dòng)態(tài)創(chuàng)建表單的方法
這篇文章主要介紹了angular學(xué)習(xí)之動(dòng)態(tài)創(chuàng)建表單的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12使用xampp將angular項(xiàng)目運(yùn)行在web服務(wù)器的教程
這篇文章主要介紹了使用xampp將angular項(xiàng)目運(yùn)行在web服務(wù)器,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09AngularJS實(shí)現(xiàn)網(wǎng)站換膚實(shí)例
這篇文章主要為大家詳細(xì)介紹了AngularJS實(shí)現(xiàn)網(wǎng)站換膚的簡單實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12Angular2生命周期鉤子函數(shù)的詳細(xì)介紹
這篇文章主要介紹了Angular2生命周期鉤子函數(shù)的詳細(xì)介紹,Angular提供組件生命周期鉤子,可以讓我們更好的開發(fā)Angular應(yīng)用,有興趣的可以了解一下2017-07-07妙用Angularjs實(shí)現(xiàn)表格按指定列排序
使用AngularJS的過濾器,可以很容易的實(shí)現(xiàn)在表格中,點(diǎn)擊某一列標(biāo)題進(jìn)行排序,實(shí)現(xiàn)代碼也很簡單,下面小編給大家分享angularjs實(shí)現(xiàn)表格按指定列排序的實(shí)現(xiàn)代碼,需要的的朋友參考下吧2017-06-06