百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

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/?输出的内容。其实主要用到的参数也就几个。...

如何彻底删除电脑文件?怎么防止删除文件恢复?

数据安全可以说是信息时代的一大安全隐患,如果我们打算把电脑和硬盘变卖或转赠他人,那么彻底删除电脑文件和防止删除的文件被恢复是非常重要的操作,下面分别予以说明。一、如何彻底删除电脑文件...