Angular directive递归实现目录树结构代码实例
更新时间:2017年5月9日 10:00 点击:2358
整理文档,搜刮出一个Angular directive递归实现目录树结构代码实例代码,稍微整理精简一下做下分享。
效果图:
重点:
1. 整棵目录树的实现,通过嵌套完成,主要在于对treeItem.html的递归使用
<script type="text/ng-template" id="treeView.html"> <ul> <li ng-repeat="item in treeData.children" ng-include="'treeItem.html'"></li> </ul> </script> <script type="text/ng-template" id="treeItem.html"> <span class="color-indictor" ng-class="{'leaf-node': isLeaf(item), 'expand-node': !isLeaf(item) && item.isExpand, 'unexpand-node': !isLeaf(item) && !item.isExpand}" ng-click="toggleExpandStatus(item)"></span> <span>{{item.name}}</span> <ul ng-if="!isLeaf(item)" ng-show="item.isExpand"> <li ng-repeat="item in item.children" ng-include="'treeItem.html'"></li> </ul> </script>
2. 点击展开/关闭目录树
通过ng-show对item.expand进行判断,点击item时切换其expand参数,完成目录树的打开与关闭
3. 源码
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.9/angular.js"></script> <script> angular.module("treeApp", []) .controller("treeController", function($scope){ $scope.jsonData = { name: 'menu', children: [{ name: 'A', children: [{ name: 'A.1', children: [{ name: 'A.1.1', children: [] }] },{ name: 'A.2', children: [{ name: 'A.2.1', children: [{ name: 'A.2.1.1', children: [] }] },{ name: 'A.2.2', children: [] }] }] },{ name: 'B', children: [{ name: 'B.1', children: [] },{ name: 'B.2', children: [] }] },{ name: 'C', children: [] }] }; }).directive('treeView', function(){ return { restrict: 'E', templateUrl: 'treeView.html', scope: { treeData: '=' }, controller: function($scope){ $scope.isLeaf = function(item){ return !item.children || !item.children.length; }; $scope.toggleExpandStatus = function(item){ item.isExpand = !item.isExpand; }; } }; }); </script> <style> ul{ list-style: none; } .color-indictor{ display: inline-block; width: 20px; height: 20px; cursor: pointer; } .color-indictor.leaf-node{ background: red; } .color-indictor.unexpand-node{ background: green; } .color-indictor.expand-node{ background-color: yellow; } </style> <body ng-app="treeApp" ng-controller="treeController"> <div> <p>Introduce: Click green block expand the menu tree</p> <p>Red: Leaf node, can not click</p> <p>Green: Unexpand node, click to expand menu</p> <p>Yellow: Expanded node, click to unexpand menu</p> </div> <tree-view tree-data="jsonData"></tree-view> </body> <script type="text/ng-template" id="treeView.html"> <ul> <li ng-repeat="item in treeData.children" ng-include="'treeItem.html'"></li> </ul> </script> <script type="text/ng-template" id="treeItem.html"> <span class="color-indictor" ng-class="{'leaf-node': isLeaf(item), 'expand-node': !isLeaf(item) && item.isExpand, 'unexpand-node': !isLeaf(item) && !item.isExpand}" ng-click="toggleExpandStatus(item)"></span> <span>{{item.name}}</span> <ul ng-if="!isLeaf(item)" ng-show="item.isExpand"> <li ng-repeat="item in item.children" ng-include="'treeItem.html'"></li> </ul> </script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
上一篇: Vue中使用vux的配置详解
下一篇: 微信小程序开发图片拖拽实例详解
相关文章
- 这篇文章主要介绍了Angular性能优化之第三方组件和懒加载技术,对性能优化感兴趣的同学,可以参考下...2021-05-11
- 这篇文章主要给大家介绍了关于Angular利用HTTP POST下载流文件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用Angular具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-26
- 这篇文章主要给大家介绍了关于Angular如何处理未可知异常错误的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-01-17
使用Angular CDK实现一个Service弹出Toast组件功能
本文主要写用cdk实现一个简单的Toast组件,使用的是cdk中的overlay模块,需要手动安装环境,具体安装方法及相关实现代码跟随小编一起看看吧...2021-07-28详解JavaScript的AngularJS框架中的作用域与数据绑定
这篇文章主要介绍了JavaScript的AngularJS框架中的作用域与数据绑定,包括作用域的继承以及数据的单向和双向绑定等重要知识点,需要的朋友可以参考下...2016-03-07- 本篇文章主要介绍了AngularJS的ng-click传参的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...2017-06-24
- 这篇文章主要介绍了Angular实现form自动布局的相关资料,以代码片段的形式分析了Angular实现form自动布局的实现方法,感兴趣的小伙伴们可以参考一下...2016-02-01
- 本篇文章主要介绍了ionic+AngularJs实现获取验证码倒计时按钮,具有一定的参考价值,有兴趣的可以了解一下。...2017-04-27
- 这篇文章主要介绍了Angular ng-class的知识,并整理了相关资料,有兴趣的小伙伴可以参考下...2016-10-03
- 这篇文章主要介绍了初识angular框架后的所思所想,学习认识angular后的一些个人问题总结,需要的朋友可以参考下...2016-02-21
- 这篇文章主要介绍了AngularJS中实现用户访问的身份认证及表单验证功能的方法,Angular是Google开发的一款浏览器端的高人气JavaScript框架,需要的朋友可以参考下...2016-04-23
- 本篇文章主要介绍了AngularJS ui-router (嵌套路由)实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。...2017-03-13
Nginx反向代理proxy_cache_path directive is not allowed错误解决方法
这篇文章主要介绍了Nginx反向代理proxy_cache_path directive is not allowed错误解决方法,需要的朋友可以参考下...2016-01-27Angular 根据 service 的状态更新 directive
Angular JS (Angular.JS) 是一组用来开发Web页面的框架、模板以及数据绑定和丰富UI组件。本文给大家介绍Angular 根据 service 的状态更新 directive,需要的朋友一起学习吧...2016-04-06- 这篇文章主要给大家介绍了关于Angular CLI发布路径的配置项的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-28
- 在本篇内容里我们给大家整理了关于C#中使用angular的方法以及具体步骤内容,有兴趣的朋友们学习下。...2020-06-25
- 这篇文章主要给大家介绍了关于angular浏览器兼容性问题的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者使用angular具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-26
AngularJS使用angular-formly进行表单验证
这篇文章主要介绍了AngularJS使用angular-formly进行表单验证的相关资料,需要的朋友可以参考下...2015-12-29- 这篇文章主要介绍了AngularJS框架中数据的双向绑定运用实例,包括数据绑定中的关键函数与监听器触发的相关讲解,需要的朋友可以参考下...2016-03-07
Angular directive递归实现目录树结构代码实例
本篇文章主要介绍了Angular directive递归实现目录树结构代码实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...2017-05-09