首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
Linux资讯 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>编程开发>java>Java基础>正文

基于AJAX的动态树型结构的设计与实现

http://www.oklinux.cn  2008-01-20  来源: 赛迪网 langhua983  会员收藏  游客收藏  【 】 

树型结构是一类应用非常广泛的数据结构。人类社会中宗族的族谱和现代企业的组织形式都是树型结构。在计算机领域中,文件系统中文件的治理结构、存储器治理中的页表、数据库中的索引等也都是树型结构。随着Internet的飞速发展,树型结构在浏览器/服务器(Browser/Server,简称B/S)应用系统的应用也越来越广泛。

 目前,在互联网上广泛存在、应用的树型结构一般分为两种:静态和动态结构。静态结构存在最多、实现简单,但是静态导致不能改变树的结构和内容,无法反映树的节点信息的变化;而实现相对复杂的动态构造树,虽然可以动态增加、删除、更新节点信息,但是大部分不能直接拖放节点来改变树的结构以及节点间的次序,并且反复刷新整个页面,给用户维护带来了许多不便。本文提出了一种基于Ajax(Asynchronous JavaScript and XML)通用的、动态加载节点的解决方案。实现上采用J2EE多层架构,树节点的描述信息采用数据库存储,以可扩展标记语言(eXtensible Markup Language,简称XML)展现给JavaScript解析,支持无刷新地增加、删除、更新节点信息,以及拖放节点来改变树的结构和节点间的次序。文中第1部分简要介绍了Ajax技术;第2部分具体介绍了该方案的技术实现过程;第3部分分析了该方案的效率。

 1、Ajax简介

 Ajax概念的最早提出者Jesse James Garrett认为:Ajax并不是一门新的语言或技术,它实际上是几项技术按一定的方式组合在共同的协作中发挥各自的作用,它包括:

 ?使用扩展超媒体标记语言(eXtended Hypertext Markup Language,简称XHTML)和级联样式单(Cascading Style Sheet,简称CSS)标准化呈现;

 ?使用文档对象模型(Document Object Model,简称DOM)实现动态显示和交互;

 ?使用可扩展标记语言(eXtensible Markup Language,简称XML)和可扩展样式表转换(eXtensible Stylesheet Language Transformation,简称XSLT)进行数据交换与处理;

 ?使用XMLHTTP组件XMLHttpRequest对象进行异步数据读取;

 ?最后用JavaScript绑定和处理所有数据。

 Ajax的工作原理如图1所示,它相当于在用户和服务器之间加了一个中间层,使用户操作与服务器响应异步化。并不是所有的用户请求都提交给服务器,像?些数据验证和数据处理等都交给Ajax引擎处理,只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求。这样就把一些服务器负担的工作转嫁到客户端,利用客户端闲置的处理能力来处理,减轻服务器和带宽的负担,从而达到节约ISP的空间及带宽租用成本的目的。



     图 1 未使用Ajax(a)和使用Ajax(b)的web应用比较

 2、总体设计方案

 传统的服务器程序采用Model 1开发模型,通常将业务逻辑、服务器端处理过程和HTML代码集中在一起表示,快速完成应用开发。Model 1 在小规模应用开发时优势明显,但是应用实现一般是基于过程的,一组服务器页面实现一个流程,假如流程改动将导致多个地方修改,非常不利于应用的扩展和更新。此外业务逻辑和表示逻辑混合在服务器页面中,耦合紧密,无法模块化,导致代码无法复用。

 Model 2则解决了这些问题,它是面向对象的MVC模式(Model-View-Controller,模型-视图-控制器)在Web开发中的应用,Model表示应用的业务逻辑,View是应用的表示层页面,Controller是提供给用的处理过程控制。通过这种MVC设计模式把应用逻辑,处理过程和显示逻辑划分成不同的组件、模块实现,组件间可以进行交互和重用。

 本方案是采用J2EE的多层架构,设计时结合Struts框架将表示层、业务逻辑层和数据层划分成不同的模块。表示层专注于树的外观显示,业务逻辑层为服务器端处理程序,处理树的生成、变化,为减少耦合性,该程序全部模块化实现,不在表示页面嵌入服务器程序;模型层是数据的存储和表示。下面分别介绍各层实现。

 2.1 表示层实现

 类似Windows资源治理器的文件夹模式,节点的图片样式如表1所示。对于每个节点的DHTML 代码,需要包含节点的位置、前导图片、样式、针对该节点的其他操作等。同时为了节点显示的连贯性,还需一些前导图片。

 表1 树节点的前的图片样式表
  

 对于树的非叶子节点,图片和节点信息等,采用一个DIV ( division) 容器包含。DIV 等容器是DHTML 的基础,使用它可以通过脚本程序对其属性进行操作,如设置其style 样式的display 属性来控制子节点的展开和隐藏。节点的位置、前导图片、样式、针对该节点的其他的操作等都放入容器中,例: < DIV id =mParentID>
< IMG align = center border = 0 onclick =″nodeExpand (‘leafid’)″ name = m1Tree src =′Tplus.gif′>
< IMG align = center border = 0 name = m1Folder src =′folderClosed. gif′> 计算机学院 </DIV>


 叶子节点无需容器直接输出即可。

 当点击某节点前的“ ”、“ - ”图片时通过DIV 的style 样式的display 属性控制子节点的展开和隐藏。display:“none”(隐藏,不可见),display:“block”(显示) 。相关JavaScript 代码如下:

if (expandChild.style.display = =″none″){
 // 当前为隐藏状态,执行展开动作
 this.Loading(parentObject);//判定该分支的数据是否已经加载
 expandChild.style.display =″block″;
if (para2 = =″last″)
 parentObject.src =″Lminus. gif″; // 最后一个节点
else
 parentObject.src = ″Tminus. gif″; // 显示┠
 expandFolder.src = ″folderOpen. gif″;
}else {
 // 将当前节点的子节点全部隐藏
 expandChild.style.display = ″none″;
 if (para2 = = ″last″)
  parentObject.src = ″Lplus. gif″;
 else
  parentObject.src = ″Tplus. gif″;
  expandFolder.src = ″folderClosed. gif″;
}

 2.2 树型表结构设计

 我们以数据库为载体记录节点的变化,树型表结构至少要有以下字段:节点的编号(CLASSID) ,对节点的描述(ClassName),父节点的编号(ParentId),这些是构建树结构所必须的信息。同时引入节点的类别代码(ClassCode),节点的级别(ClassLevel),是否叶子节点 (Terminated)等辅助字段,记录节点次序,实体关系图如图3所示。

共3页: 上一页 1 [2] [3] 下一页

上一篇:I/O及网络--一个简单的文件传送代码   下一篇:J2ME综合--谈谈J2ME的几个重要的功能


收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·J2ME综合--谈谈J2ME的几个重要的功能
·I/O及网络--一个简单的文件传送代码
·J2SE综合介绍:与你一起讨论AJAX进一阶应用
·J2SE综合:浅析Java语言中两种异常的差别
·J2ME综合--J2ME应用程序内存优化三招
·数据库相关:小结Hibernate的查询方式
·I/O及网络--MD5加密及Java的实现方式
·J2ME综合--JAR文件包及jar命令详解
·Java GUI:Java布局管理器使用方法探讨
·高级:Cookie,httpsession类使用概述
·浅析Spring2.0中新的Bean类型实现原理
·服务器及中间件:JBoss4.0数据源配置大全
·高级:使用异步Servlet扩展AJAX应用程序
·通过Hibernate_tool生成代码和映射文件
·J2SE综合--区分eclipse中的两种JRE
·J2SE综合--java通过JNI与delphi交互
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·Java入门:状态对象--数据库的替代者
·Java语言怎样调用外部应用程序
·Java语言深入--关于Java语言的内存泄漏
·JSP/Servlet/JSF:Servlet/JSP配置详解
·进阶-怎样使用AJAX进行WEB应用程序开发
·基础:J2ME程序开发之新手入门九大要点
·Java入门--Java语言接口与继承的本质
·JAVA进阶--如何提升JSP应用程序的效率
·对Java中四种XML解析技术之不完全测试
·编写高级 JScript应用代码
·JSP/Servlet/JSF--对标签库的深入研究
·Java入门--关于字符串分割的两种方法
  阅读排行
·使用AJAX技术实现网页无闪自动局部刷新
·快速教您Apache Tomcat SSL的配置
·Java语言深入--java调用C/C 的过程
·用JSP JavaScript打造二级级联下拉菜单
·JAVA进阶--线程运行栈信息的获取讲解
·J2SE综合--JAVA实现把汉字转化成拼音
·使用WEBWORK实现文件上传方法实例详解
·一个非常有趣的使用spring框架AOP例子
·关于java中相对路径,绝对路径问题总结
·高级:lucene全文检索应用示例及代码简
·详细讲解Struts构架中action的跳转大全
·在Weblogic上配置JMS服务的方法
·Hibernate配置文件中的映射元素详解
·对Java中四种XML解析技术之不完全测试
·数据库相关:小结Hibernate的查询方式
网摘收藏: