boostrap中的树图--treeview
csdh11 2025-04-26 17:30 3 浏览
以下将要介绍下 bootstrap 中treeview 树图的核心代码咯!!
先看下效果图吧:
如上图所见,如果您的前端用的bootstrap,那用treeview 的话 样式就比较统一了。
因为个人局的treeview 其实不是很好的。只不过样式好统一,不然我也不会选他,这玩意方法少,比如你来个异步加载之类的操作,比较麻烦。
因此,用到了它,我觉得最方便的 就是一次性获取他的节点数据,这个要么前台js 使用递归,要么后台使用递归,为了代码 重用性。我选择了后台递归,从数据库检索了数据后,通过递归拼出tree 的每个节点需要的属性,也就是构造节点了。下面贴出一段递归的代码啦,供需要的人参考:
public List<Map<String, Object>> queryDirTree(HttpServletRequest request, HttpServletResponse response, CPcProductFunDir cdt, String orders){ //从数据库中查找数据 返回集合 List<PcProductFunDir> ls = productFunPeer.queryDirList(cdt, orders); //遍历集合 for(int i=0; i<ls.size; i++) { //获取每个节点对象 PcProductFunDir dir = ls.get(i); Long parentId = dir.getParentId; //判断他们的父节点id是否为空,为空则赋值为0 if(parentId == null) { dir.setParentId(0l); } } //定义分组map 以parentId 分组 Map<Long, List<PcProductFunDir>> groupMap = BinaryUtils.toObjectGroupMap(ls, "parentId"); //定义集合用于保存节点 List<Map<String, Object>> data = new ArrayList<Map<String, Object>>; //调用递归方法 toTreeViewData(groupMap, data, 0l); return data; //返回结果 } /** * 递归处理treeview 数据 * @param groupMap 分组map(按parentId分组) * @param childsData 子节点 * @param parentId 父级id */ private void toTreeViewData(Map<Long, List<PcProductFunDir>> groupMap, List<Map<String, Object>> childsData, Long parentId) { //根据父级id从 groupMap中 取出对应的集合 List<PcProductFunDir> dirChilds = groupMap.get(parentId); //判断子级节点集合时候为空 if(dirChilds==null || dirChilds.size==0) return ; //遍历子级节点集合 for(int i=0; i<dirChilds.size; i++) { //获取对象 PcProductFunDir dir = dirChilds.get(i); //定义map Map<String, Object> map = new HashMap<String, Object>; //将treeview 所需属性作为key,与已有对应数据作为value 存入map map.put("id", dir.getId); map.put("text", "["+dir.getDirCode()+"] " + dir.getDirName); map.put("icon", dir.getIcon); map.put("tags", new String{String.valueOf(dir.getParentId)}); //一个节点完成了,存入节点map中 childsData.add(map); //再以当前 取出对象(子级节点)的id 作为父id 从groupMap 中取出对应的集合 List<PcProductFunDir> ls = groupMap.get(dir.getId); //判断 取出的集合是否为空,不为空 则当前子级节点下还有子节点 if(ls!=null && ls.size>0) { //创建 集合保存子节点 List<Map<String, Object>> subData = new ArrayList<Map<String, Object>>; //递归调用 toTreeViewData(groupMap, subData, dir.getId); //将获取到的 叶子节点 集合放入 当前节点 的 nodes(子节点属性) 中 map.put("nodes", subData); } } }
ok 啦!! 当然我给出的只是方法,每个公司 用的框架不一样,这个处理数据的方法通用就行了
这后台获取数据再递归拼除treeview节点,跟前台那是省了一大堆事呢!我觉得,好了,后台完了,到前台了,简单很多了:
function refreshTreeview { //可以用ajax请求数据 $.ajax({url:"能获取到后台数据的请求路径",data:{....},success:function(rs) { $("#treeview").treeview({ data: rs, levels: 1, showIcon: true, showBorder: false, selectedBackColor:"#d0f0f0", selectedColor:"#428bca", selectedIcon: "fa fa-stop", onNodeSelected:onTreeClick }); }}); }
欧啦!就用ajax获取数据,调用后台的那个方法就好了,至于页面对应id为 treeview 标签,就一个div 就好了
<div id="treeview"></div>
那么接下来,这个div想怎么放,爱怎么放怎么放吧,嘿嘿^_^....
还有就是js里的 构造treeview的那部分,我给出的样式也比较简单,还有那些 属性就不一一介绍了,去jQuery之家看看就知道了,想要更炫的效果,再加就好。
写完发现,我这不按常理了 ,人家都是从前到后,我是从后往前^o^....看到的童鞋凑合着看吧
相关推荐
- 一文了解NTFS和FAT32的真正区别
-
FAT32文件系统是在win98时代最常用的文件系统。而NTFS文件系统在winxp的时代开始流行,一直持续到现在。它们之间有什么区别呢?主要有四个方面的区别。1、兼容性FAT32文件系统是在1997...
- 海韵教育丨系统文件和系统文件夹解析
-
系统文件夹...
- DOSBox 使用指南:在现代电脑上重温经典 DOS 游戏
-
想在Windows、Mac或Linux上玩经典的DOS游戏?DOSBox让你轻松实现!DOS时代的经典游戏,比如《毁灭战士(Doom)》《波斯王子(PrinceofPersia)》...
- Windows系统CMD-DOS命令大全及CMD命令与运行命令的区别
-
Windows系统CMD-DOS命令和开始→运行(win+R)命令的区别...
- 如何批量修复dll动态链接库文件
-
系统安装文件夹中存在以dll为后缀的动态链接库文件,它们为系统和软件提供底层支持。有时安装软件后,可能会遇到无法连接dll文件的提示。如何修复这些问题?下面将为大家介绍dll动态链接库的修复方法,跟随...
- Dos命令大全
-
1.#查看当前所在目录文件dir2.#切换目录cdchangedirector3.#返回上一级cd..4.#清除屏幕cls(clearscreen)5.#退出终端exit6.#查看电...
- dos命令net share图文教程,创建删除显示网络计算机电脑共享资源
-
大家好,我是老盖,首先感谢观看本文,本篇文章做的有视频,视频讲述的比较详细,也可以看我发布的视频。今天我们学习net命令中的share这个命令,它这个命令可以创建删除电脑的共享资源,输入命令nets...
- 硬盘坏道修复
-
硬盘出现坏道是致命故障,若坏道频繁发生,可能表明硬盘寿命将尽。此时应警惕,妥善保存数据,随时准备更换新硬盘。硬盘坏道分为物理坏道和逻辑坏道两类,需区别对待处理。1、硬盘出现坏道后,不仅部分扇区无法使...
- 经典重温:Windows 95系统
-
2014-11-2605:03:00作者:李英杰科技在快速发展,桌面操作系统也在不断更新换代。作为有史以来最成功的操作系统之一,Windows95相比之前的Win3.x在界面和功能上实现了巨大...
- 电脑键盘各键名称及功能
-
了解电脑操作快捷键,高效使用电脑,提高工作效率。电脑键盘功能示意图:各个区中各键名称:各键功能:PageDown:向下翻页键。Page,页的意思,Down,向下的意思。和Pageup键相呼应。笔记本键...
- DOS命令-出错提示与对策
-
[英文提示]Generalfailure[中 文]通用失败[原 因]DOS不能判断错误的原因,一般是因为驱动器中的磁盘未格式化,或格式化成非DOS系统。[对 策]应该重新格式化磁...
- EXCEL一篇搞定,根据当天日期批量创建数百个文件夹
-
我是做销售统计的,每天都需要收集门店的日报,每天都需要针对每个门店创建一个文件夹第一层是日期,然后是门店名称对应的文件夹我每天都要一个一个创建,现在门店多了,创建都花了半天时间,有简单的方法吗?我太难...
- Win10彻底删除Java1.8流程
-
一定要先将环境变量删除再卸载jdk,最后删除注册表...
- 批处理命令——玩转目录之dir
-
我在前面系列的批处理文章中曾提到过dir这个dos命令,它是显示目录或文件的一个命令,那么它详细的用途是什么呢,我们使用它时又需要注意什么呢?上面是dir/?输出的内容。其实主要用到的参数也就几个。...
- 如何彻底删除电脑文件?怎么防止删除文件恢复?
-
数据安全可以说是信息时代的一大安全隐患,如果我们打算把电脑和硬盘变卖或转赠他人,那么彻底删除电脑文件和防止删除的文件被恢复是非常重要的操作,下面分别予以说明。一、如何彻底删除电脑文件...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)