http://luohua.iteye.com/blog/451453

dTree 主页:http://destroydrop.com/javascripts/tree/

dTree是个很方便在页面生成树的 js 控件,如果你下载了,我猜里在几分钟之内便能在页面上显示出一颗树来。

它本身给的例子是通过一些静态数据构造树,下面我说一种通过查询的数据动态构造树的方法。

例子里没有真实的数据库操作,而是用一个模拟的数据库操作类替代。

在该例子中为了简便和理解没有分为过多的层,仅有 页面显示层 和 模拟的 数据库层。

最后对页面上有逻辑代码的问题作了下改进。

首先看看model 类,如下:

  1. public class Node {
  2. private int id;
  3. private String name;
  4. private int pId;
  5. public Node(){}
  6. public Node(int id, String name, int pId){
  7. this.id = id;
  8. this.name = name;
  9. this.pId = pId;
  10. }
  11. public int getId() {
  12. return id;
  13. }
  14. public void setId(int id) {
  15. this.id = id;
  16. }
  17. public String getName() {
  18. return name;
  19. }
  20. public void setName(String name) {
  21. this.name = name;
  22. }
  23. public int getPId() {
  24. return pId;
  25. }
  26. public void setPId(int id) {
  27. pId = id;
  28. }
  29. }

model 类很简单,并且只包含了构造一个树必要的几个属性,结点id,结点名字和结点父id。

下面再来看下上面 model 的 数据库操作类,里面构造了一些数据,并有一些得到数据的方法,如下:

  1. public class NodeDb {
  2. private static List<Node> treeList;
  3. static{
  4. treeList = new ArrayList<Node>();
  5. Node n = new Node(0,"Book",-1);
  6. treeList.add(n);
  7. n = new Node(1,"Computer",0);
  8. treeList.add(n);
  9. n = new Node(2,"Java",1);
  10. treeList.add(n);
  11. n = new Node(3,"C#",1);
  12. treeList.add(n);
  13. n = new Node(4,"Php",1);
  14. treeList.add(n);
  15. n = new Node(5,"Thinking in Java",2);
  16. treeList.add(n);
  17. n = new Node(6,"Java Core",2);
  18. treeList.add(n);
  19. n = new Node(7,"Thinking in C#",3);
  20. treeList.add(n);
  21. n = new Node(8,"C# Core",3);
  22. treeList.add(n);
  23. n = new Node(9,"Thinking in Php",4);
  24. treeList.add(n);
  25. n = new Node(10,"Php Core",4);
  26. treeList.add(n);
  27. }
  28. public List<Node> getNodes(){
  29. return treeList;
  30. }
  31. }

然后再看下页面,

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ page import="dtree.model.*" %>
  4. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  5. <%@page import="dtree.db.NodeDb"%>
  6. <%@page import="java.util.Iterator"%><html>
  7. <head>
  8. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  9. <title>Show Tree</title>
  10. <link rel="StyleSheet" type="text/css" href="dtree.css" />
  11. <script type="text/javascript" src="dtree.js"></script>
  12. </head>
  13. <body>
  14. <%
  15. NodeDb ndDb = new NodeDb();
  16. Iterator<Node> treeIt = ndDb.getNodes().iterator();
  17. StringBuffer sbf = new StringBuffer();
  18. // 定义js树对象
  19. sbf.append("dtree = new dTree(\"dtree\");");
  20. while(treeIt.hasNext()){
  21. Node nd = treeIt.next();
  22. // 增加 js树结点
  23. sbf.append("dtree.add("+nd.getId()+","+nd.getPId()+",\""+nd.getName()+"\");");
  24. }
  25. // 输出js树
  26. sbf.append("document.write(dtree);");
  27. %>
  28. <script type="text/javascript">
  29. // 执行生成的js字符串
  30. eval('<%=sbf.toString()%>');
  31. </script>
  32. </body>
  33. </html>

就这样几步,我们并能通过从(模拟)数据库里取出的数据动态的在页面上生成我们的树,如下显示:

到此为止,一个完整的树已经建立完成,可以看到这个过程非常简单。

但上面的页面代码中有个问题,就是包含了大量的逻辑代码,为了减少这些代码以让页面代码更象“页面代码”,将上面的例子作如下改变:

首先,我们在 数据库操作类里新增一个方法,很显然该方法便是用来生成 js 字符串的,如下:

  1. // 返回定义且生成页面树的 js 字符串
  2. public String getJSTreeString(){
  3. Iterator<Node> treeIt = getNodes().iterator();
  4. StringBuffer sbf = new StringBuffer();
  5. // 定义js树对象
  6. sbf.append("dtree = new dTree(\"dtree\");");
  7. while(treeIt.hasNext()){
  8. Node nd = treeIt.next();
  9. // 增加 js树结点
  10. sbf.append("dtree.add("+nd.getId()+","+nd.getPId()+",\""+nd.getName()+"\");");
  11. }
  12. // 输出js树
  13. sbf.append("document.write(dtree);");
  14. return sbf.toString();
  15. }

然后再看看这次少得可怜的页面代码:

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <%@page import="dtree.db.NodeDb"%><html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Show Tree</title>
  8. <link rel="StyleSheet" type="text/css" href="dtree.css" />
  9. <script type="text/javascript" src="dtree.js"></script>
  10. </head>
  11. <body>
  12. <script type="text/javascript">
  13. eval('<%=new NodeDb().getJSTreeString()%>');
  14. </script>
  15. </body>
  16. </html>

这样改后,运行效果与前面完全一样。

上面的例子是对一个具体的业务生成的一颗树,如果我们的 model 改变,则需要完全再重写生成树的代码,所以可以考虑利用反射机制写一个通用的生成树的类,不过有没有这个必要也不好说,因为一个项目应该也不会有很多颗树,而且不用反射来的更快些。

其实生成一颗符合需求的树远远没有上面那么简单,不过 dTree 也能做出功能很强大的树来,这需要在构造结点时添加更多需要的属性,其实方法与上面还是一样,参考文档即可。

如果有其他方法请与我分享,谢谢。

dTree 动态生成树的更多相关文章

  1. dTree动态生成树(后台处理,简化前台操作)

    dTree是个很方便在页面生成树的 js 控件,如果你下载了,我猜里在几分钟之内便能在页面上显示出一颗树来. 它本身给的例子是通过一些静态数据构造树,下面我说一种通过查询的数据动态构造树的方法. 例子 ...

  2. jstree动态生成树

    前篇文章简单介绍了静态生成树,这篇文章将通过后台把数据通过json形式传到前台,进行动态生成树. 本篇的程序所用框架为Spring MVC,可以很方便的通过controller层传json到前台. 前 ...

  3. JSON动态生成树

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. ztree实现左边动态生成树,右边为具体信息功能

    页面原型图: 图片.png 功能需求:点击左边树上的子节点,像后台发送请求,将请求到的信息展示在右边的表单里面 前端代码实现: 引入css文档: <link rel="styleshe ...

  5. jstree静态生成树并为树添加触发事件

    本章将介绍如何简单的使用jstree生成树(生成树的数据是静态的),并为树添加点击事件. 1. 建一个jsp页面,引入jquery.js(在其他js前引用),引入jstree所需的js,css文件(可 ...

  6. Spring多数据源解决方案

    Figure 2 多数据源的选择逻辑渗透至客户端 解决方案 Figure 3 采用Proxy模式来封转数据源选择逻辑 通过采用Proxy模式我们在方案实现中实现一个虚拟的数据源.并且通过它来封装数据源 ...

  7. Ext.Net学习笔记23:Ext.Net TabPanel用法详解

    Ext.Net学习笔记23:Ext.Net TabPanel用法详解 上面的图片中给出了TabPanel的一个效果图,我们来看一下代码: <ext:TabPanel runat="se ...

  8. [LCT应用]

    维护动态生成树,建树方法:假设边edge(x,y),则建立x ->edge->y的先后顺序.

  9. Web应用程序开发,基于Ajax技术的JavaScript树形控件

    感谢http://www.cnblogs.com/dgrew/p/3181769.html#undefined 在Web应用程序开发领域,基于Ajax技术的JavaScript树形控件已经被广泛使用, ...

随机推荐

  1. phpldapadmin具体设置

    一.需求    1.属性隐藏 只显示用户名,部门(因为是单OU设计为了做区分),登录密码 2.属性顺序显示 部门>用户名>登录密码 3.使用UID可以登陆 用户可以使用账户(自己的名字)登 ...

  2. JAVA学习笔记--字符串概述

    一.String类 String类代表字符串,是由字符构成的一个序列.创建String对象的方法很简单,有以下几种: 1)用new来创建: String s1 = new String("m ...

  3. DeepLearning - Regularization

    I have finished the first course in the DeepLearnin.ai series. The assignment is relatively easy, bu ...

  4. win7重装系统后设置Python2.7环境

    起因 台式机的主板莫名出现问题,显示器画面卡顿不能动,鼠标键盘无反应,在这种情况下只好按住电源键断电.下面重启后,显示器无画面,猜测开机后没有进BIOS.然后就拆机箱,拔下电源线后撬起主板电池几秒再放 ...

  5. charles 在mac下 抓取 https包

    1.  打开charles --> help --> SSL proxying --> install charles root certificate 2. 在弹出的添加证书窗口中 ...

  6. Android数据储存之SQLiteDatabase 简单增删改查

    SQLiteDatabase 使用 SQLiteDatabase提供如下方法来打开一个文件对应的数据库: openDatabase(String path, SQLiteDatabase.Cursor ...

  7. c# 窗体与窗体外的文件互动(拖拽)

    大部分控件都有此事件drag相关. 以picturebox为例: pictureBox1.AllowDrop = true;//此属性需要全打出来,不会自动识别添加 private void pict ...

  8. Python:Python的运行过程

    1.Python是什么 和Java以及c#一样,Python也是一门基于虚拟机的语言.熟悉Java开发的人在命令行执行一个Java程序的过程通常如下: javac hello.java java he ...

  9. SGU 126 Boxes(模拟题|二进制)

    Translate:Sgu/126 126. 盒子 time limit per test: 0.5 sec. memory limit per test: 4096 KB 有两个盒子. 第一个盒子里 ...

  10. UVALive 6913 I Want That Cake 博弈+dp

    题目链接: http://acm.hust.edu.cn/vjudge/problem/96343 I Want That Cake Time Limit: 3000MS 64bit IO Forma ...