成熟丰满熟妇高潮XXXXX,人妻无码AV中文系列久久兔费 ,国产精品一国产精品,国精品午夜福利视频不卡麻豆

您好,歡迎來(lái)到九壹網(wǎng)。
搜索
您的當(dāng)前位置:首頁(yè)AngularJS遞歸指令實(shí)現(xiàn)TreeView效果示例

AngularJS遞歸指令實(shí)現(xiàn)TreeView效果示例

來(lái)源:九壹網(wǎng)

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

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

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

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

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

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

我們就可以如下方式來(lái)使用這個(gè)tree-view:

<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>

Copyright ? 2019- 91gzw.com 版權(quán)所有 湘ICP備2023023988號(hào)-2

違法及侵權(quán)請(qǐng)聯(lián)系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市萬(wàn)商天勤律師事務(wù)所王興未律師提供法律服務(wù)