一个简单的树型目录实现

原创 2008年04月28日 10:48:00

一个简单的树型XML文档的生成

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.output.XMLOutputter;

import com.shinecode.cybertraining.domain.Chapter;

/**
 * 类名:CreateTreeXml.java
 * 版本:
 * 更新日期:2008-4-24
 * 作者:Java.newlife
 * 功能描述:生成树型目录的XML文档
 */
public class CreateTreeXml {

 private Element root = new Element("nodes");

 private Document doc = new Document(root);

 private String path = null;

 public CreateTreeXml(){
  
 }
 
 public CreateTreeXml(String path) {
  this.path = path;
 }
 
 /*创建树的入口*/
 private void start(List<Tree> list)
 {
  Element e = null;
  createFile(0,e,list);
 }

 //要注意一下的,生成节点时
 private void createFile(int PId,Element p, List<Tree> list)
 {
  if(p == null) p = root;
  StringBuffer sb = new StringBuffer();
  for(int i = 0;i<list.size();i++)
  {
   Tree  temp = (Tree) list.get(i);

   //创建当前节点对象
   Element nowNode = new Element("node");
   
   /* 存入ID时的规则(1.只用当前ID;2.用父ID+当前ID)*/
   sb.delete(0, sb.length());
  // sb.append(temp.getParentId()); 
   sb.append(temp.getId());
   
   nowNode.setAttribute("id",sb.toString());
   nowNode.setAttribute("text",temp.getTitle());
   
   // 找到指定级别的子类
   if (PId == temp.getParentId())
   {
    // 这里是打印,可以换成输出,或是做别的处理
    System.out.println(temp.getTitle() + " parentId : " + PId);
    p.addContent(nowNode); //加入当前节点到父节点
    
    // 判断是否存在下级节点,若存在读取所有节点
    if (hasChild(list, temp.getId()))
     createFile(temp.getId(),nowNode,list);
   }
   
  }
  saveXmlFile();
 }
 
 /*把数据写入文件*/
 private void saveXmlFile()
 {
  XMLOutputter xmlout = new XMLOutputter();
  try
  {
   xmlout.output(doc,new FileOutputStream(path));
  } catch (FileNotFoundException e)
  {
   e.printStackTrace();
  } catch (IOException e)
  {
   e.printStackTrace();
  }
 }
 
 /*是否存在子节点*/
 private boolean hasChild(List<Tree> list, int parentId)
 {
  Iterator iterator = list.iterator();
  boolean bool = false;
  while (iterator.hasNext())
  {
   Tree t = (Tree) iterator.next();
   if (parentId == t.getParentId())
   {
    bool = true;
    break;
   }
  }
  return bool;
 }
 
 /*生成指定内容的XML文档(在这里我是用来生成试卷考点的XML文档)*/
 public void createChapterTree(){
  BaseService baseService = new ChapterService();
  List<Tree> treeList = new ArrayList<Tree>();
  List list = baseService.findAll();
  Iterator iterator = list.iterator();
  while(iterator.hasNext()){
   Tree tree = new Tree();
   Chapter chapter = (Chapter)iterator.next();
   tree.setId(chapter.getId());  //存入ID
   
   /*是否存在父对象*/
   if(chapter.getChapParentid() == null){  
    tree.setParentId(0);
   }else{
    tree.setParentId(chapter.getChapParentid().getId());
   }
   
   tree.setTitle(chapter.getChapName()); //节点名称
   treeList.add(tree);
  }
  start(treeList);
 }
 
 public static void main(String[] arg){
  /*测试生成XML文件开始*/
  CreateTreeXml ctx = new CreateTreeXml("Chapter.xml");
  ctx.createChapterTree();
 }

 /**
  * @return the path
  */
 public String getPath() {
  return path;
 }

 /**
  * @param path the path to set
  */
 public void setPath(String path) {
  this.path = path;
 }

}

Tree.java 是一个简单的JavaBean,有四个属性:

int id;//数据ID

int parentId;//父ID

String title;标题

int dept;//节点深度

(这里可以添加更多的属性,如:链接...)

页面显示树我用的MzTreeView2.0 ,加载生成的这个XML文件即可。。。

从零开始实现一个可用的mvc框架

从零开始,一步一步的实现一个可用的类似于springmvc的mvc框架;
  • 2017年03月08日 16:06

android treeview多层级列表树

  • 2015年03月08日 20:35
  • 63KB
  • 下载

Android中多级树目录的实现方式

  • 2014年10月26日 23:37
  • 1.61MB
  • 下载

asp实现树型目录

asp实现树型目录重要思想:递归思想数据表: id name pid ...
  • apple666999
  • apple666999
  • 2007-05-21 10:30:00
  • 448

android view树的绘制流程

转载请注明出处:http://blog.csdn.net/qinjuning                   前言: 本文是我读《Android内核剖析》第13章----V...
  • jiabailong
  • jiabailong
  • 2012-11-27 09:36:08
  • 5546

建立简单的树型目录

  • daniel75122
  • daniel75122
  • 2009-06-17 03:20:00
  • 292

巧用CSS制作树状目录

索易电子杂志大多采用树状目录,当鼠标点击主目录时,展开子目录;当再次点击主目录时,则关闭子目录。显得简捷明快,朴实无华。制作这种树状目录的方法较多,最近我利用CSS能方便地控制对象的“显示”和“隐藏”...
  • small_pig
  • small_pig
  • 2001-08-13 13:31:00
  • 793

模拟文件系统(Java版)

  • 2013年01月21日 19:41
  • 938KB
  • 下载

C#写的一个树形目录的文件管理器 源代码

  • 2009年04月09日 12:12
  • 65KB
  • 下载

如何遍历整个目录树查找文件

在应用程序的开发过程中,会遇到如何查找某一文件以确定此文件路径的问题。利用CFileFind类可以比较方便地在当前目录下进行文件查找,但却不能对其子目录中的文件进行搜寻。而实际应用中往往需要对某一整个...
  • jiht594
  • jiht594
  • 2011-07-19 15:58:40
  • 340
收藏助手
不良信息举报
您举报文章:一个简单的树型目录实现
举报原因:
原因补充:

(最多只允许输入30个字)