




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于AJAX的动态树型结构的设计与实现摘要:简要介绍了一种通用的,动态树型结构的实现方案,该方案基于AsynchronousJavaScriptandXML,结合Struts框架设计实现了结构清晰、扩展性良好的多层架构,数据存储于数据库,结合XML描述树的节点信息,使得任何按预定的XML文档描述的信息都可以通过动态树来展现。关键词:MVC模式;Ajax树型结构;字典序树型结构是一类应用非常广泛的数据结构。人类社会中宗族的族谱和现代企业的组织形式都是树型结构。在计算机领域中,文件系统中文件的管理结构、存储器管理中的页表、数据库中的索引等也都是树型结构。随着Internet的飞速发展,树型结构在浏
2、览器/服务器(Browser/Server,简称B/S)应用系统的应用也越来越广泛。目前,在互联网上广泛存在、应用的树型结构一般分为两种:静态和动态结构。静态结构存在最多、实现简单,但是静态导致不能改变树的结构和内容,无法反映树的节点信息的变化;而实现相对复杂的动态构造树,虽然可以动态增加、删除、更新节点信息,但是大部分不能直接拖放节点来改变树的结构以及节点间的次序,并且反复刷新整个页面,给用户维护带来了许多不便。本文提出了一种基于Ajax(AsynchronousJavaScriptandXML)通用的、动态加载节点的解决方案。实现上采用J2EE多层架构,树节点的描述信息采用数据库存储,以可
3、扩展标记语言(eXtensibleMarkupLanguage,简称XML)展现给JavaScript解析,支持无刷新地增加、删除、更新节点信息,以及拖放节点来改变树的结构和节点间的次序。文中第1部分简要介绍了Ajax技术;第2部分详细介绍了该方案的技术实现过程;第3部分分析了该方案的效率。1、Ajax简介Ajax概念的最早提出者JesseJamesGarrett认为:Ajax并不是一门新的语言或技术,它实际上是几项技术按一定的方式组合在共同的协作中发挥各自的作用,它包括:使用扩展超媒体标记语言(eXtendedHypertextMarkupLanguage,简称XHTML)和级联样式单(Ca
4、scadingStyleSheet,简称CSS)标准化呈现;使用文档对象模型(DocumentObjectModel,简称DOM)实现动态显示和交互;使用可扩展标记语言(extensibleMarkupLanguage,简称XML)和可扩展样式表转换(eXtensibleStylesheetLanguageTransformation,简称XSLT)进行数据交换与处理;使用XMLHTTP组件XMLHttpRequest对象进行异步数据读取;最后用JavaScript绑定和处理所有数据。Ajax的工作原理如图1所示,它相当于在用户和服务器之间加了一个中间层,使用户操作与服务器响应异步化。并不是所
5、有的用户请求都提交给服务器,像些数据验证和数据处理等都交给Ajax引擎处理,只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求。这样就把一些服务器负担的工作转嫁到客户端,利用客户端闲臵的处理能力来处理,减轻服务器和带宽的负担,从而达到节约ISP的空间及带宽租用成本的目的。图12、总体设计方案传统的服务器程序采用Model1开发模型,通常将业务逻辑、服务器端处理过程和HTML代码集中在一起表示,快速完成应用开发。Model1在小规模应用开发时优势明显,但是应用实现一般是基于过程的,一组服务器页面实现一个流程,如果流程改动将导致多个地方修改,非常不利于应用的扩展和更新。此外业务逻
6、辑和表示逻辑混合在服务器页面中,耦合紧密,无法模块化,导致代码无法复用。Model2则解决了这些问题,它是面向对象的MVC模式(Model-View-Controller,模型视图-控制器)在Web开发中的应用,Model表示应用的业务逻辑,View是应用的表示层页面,Controller是提供应用的处理过程控制。通过这种MVC设计模式把应用逻辑,处理过程和显示逻辑划分成不同的组件、模块实现,组件间可以进行交互和重用。本方案是采用J2EE的多层架构,设计时结合Struts框架将表示层、业务逻辑层和数据层划分成不同的模块。表示层专注于树的外观显示,业务逻辑层为服务器端处理程序,处理树的生成、变化
7、,为减少耦合性,该程序全部模块化实现,不在表示页面嵌入服务器程序;模型层是数据的存储和表示。下面分别介绍各层实现。表示层实现类似Windows资源管理器的文件夹模式,节点的图片样式如表1所示。对于每个节点的DHTML代码,需要包含节点的位臵、前导图片、样式、针对该节点的其他操作等。同时为了节点显示的连贯性,还需一些前导图片。表1树节点的图片样式表节点瞬节点节有子节级节点+j4_有子节点,没躺级节点J43叶子节鬆I-1丽级节点心对于树的非叶子节点,图片和节点信息等,采用一个DIV(division)容器包含。DIV等容器是DHTML的基础,使用它可以通过脚本程序对其属性进行操作,如设臵其styl
8、e样式的display属性来控制子节点的展开和隐藏。节点的位臵、前导图片、样式、针对该节点的其他的操作等都放入容器中,例:DIVid=mParentID计算机学院/DIV叶子节点无需容器直接输出即可。当点击某节点前的“+”、“-”图片时通过DIV的style样式的display属性控制子节点的展开和隐藏。display:“none”(隐藏,不可见),display:“block”(显示)。相关JavaScript代码如下:if(expandChild.style.display=none)/当前为隐藏状态,执行展开动作this.Loading(parentObject);/判断该分支的数据是否
9、已经加载expandChild.style.display=block;if(para2=last)parentObject.src=Lminus.gif;/最后一个节点elseparentObject.src=Tminus.gif;/显示卜expandFolder.src=folderOpen.gif;else/将当前节点的子节点全部隐藏expandChild.style.display=none;if(para2=last)parentObject.src=Lplus.gif;elseparentObject.src=Tplus.gif;expandFolder.src=folderClo
10、sed.gif;树型表结构设计我们以数据库为载体记录节点的变化,树型表结构至少要有以下字段:节点的编号(CLASSID),对节点的描述(ClassName),父节点的编号(Parentld),这些是构建树结构所必须的信息。同时引入节点的类别代码(ClassCode),节点的级别I(ClassLevel),是否叶子节点(Terminated)等辅助字段,记录节点次序,实体关系图如图3所示。TREE_CLASSCLASSIC:NUMBER(8)ClassCode:VARCHAE2(36)ClassNajne:VARCHAE2(40)ClassLevel:NUMBER(4)Terminated:NU
11、MBERO1Parentld:NOffiEE图3树型表结构示意图树遍历的时间复杂度是O(n),但是将树信息存放到数据库后,就不能按传统的方式遍历树,必须使用SQL语句访问数据库表的内容,而一次性取的数据量越多,消耗的资源也越多,用户等待的时间就越长。如果将无序的数据从数据库中读出,在服务器端,必须将排序后的树送到客户端显示。因此,最好从数据库读出已排好序的树。我们知道,字符串排序是按照字典序形式。结合SQL语句的特点和树结构特点,数据库表中,节点的类别代码采用多级字符串形式,如AAABBBCCC,从树根节点开始,每向下一级字符串就增加一级,并且子节点类别代码以父节点类别代码开始,再开始本级的类
12、别代码。同级的节点按照生成的顺序编号,如节点类别代码为AAA的下一级孩子类别代码为AAAAAA,AAAAAB等,AAAAAB的孩子节点为AAAAABAAA、AAAAABAAB等。每一级编号字符的宽度与实际的应用关联,如AAAZZZ级则有263个节点,如果不够用再增加一个字符用于编码。该巧妙的编号方式。使得在执行SQL语句select*fromtree_classorderbyclasscode后,一次获得完整的先序树。业务逻辑层设计2.3.1动态加载技术如果一次性获取完整的先序树,构造成xml提供给JavaScript解析,数据量越大,消耗的资源越多,客户端响应延迟时间就越长,因此对于大数据量
13、的树,采用动态加载方式,即每次单击“+图”片时,判断是否已加载子节点数据,如果未加载则通过Ajax的XMLHTTP组件XMLHTTPRequest对象异步发送请求,连接服务器执行SQL语句“select*fromtree_classwhereparent=?orderbyclasscode”获取节点数据。相关JavaScript代码如下:/*判断是否已经加载数据,未加载则访问服务器加载数据*/dhtmlTtotype.Loading=function(pObject)if(pObject.XMLload=0)&(this.XMLsource)&(!this.XMLloading)pObject
14、.XMLload=1;this.loadXML(this.XMLsource+getUrlSymbol(this.XMLsource)+id=+escape(pObject.id);dtmlXMLOtotype.loadXML=function(url)力口载数据trythis.xmlDoc=newXMLHttpRequest();/*通过GET方法异步连接到url加载数据*/this.xmlDoc.open(GET,url,true);/true:异步;false:同步this.xmlDoc.send(null);catch(e)this.xmlDoc=newActiveXObject(Mi
15、crosoft.XMLHTTP);使用IEthis.xmlDoc.open(GET,url,true);/true:异步;false:同步this.xmlDoc.send(null);returnthis.xmlDoc.responseXML;每次只取同一个父节点ParentId的子节点序列,按XML格式封装成树的文档结构,例如:treeid=0提供给JavaScript的dhtmlTreeOtotype.insertltem()解析并组织好html输出节点;其中child:1表示有子节点,0表示没有子节点;imO表示没有子节点时的图标;iml表示有子节点并且打开节点时的图标;im2表示有子节
16、点并且关闭时的图标;所以还可以在构造XML时自定义图标。2.3.2树型结构的构造从数据库中返回的是有序的先序树,而XML是完整的树型结构文档,所以将树型数据构造成预定义的XML格式,只需从根节点开始,遍历一遍树,即可将树全部生成。相关JavaScript代码如下:/*动态加载树的构造方法*/dtmlXMLOtotype.constructTree=function()采用动态加载时获取的xml数据,解析树型数据varnode=this.XMLLoader.getXMLTopNode(tree);varparentId=node.getAttribute(id);for(vari=0;inode
17、.childNodes.length;i+)逐个解析xml文件的leaf节点if(node.childNodesi.nodeType=1)&(node.childNodesi.tagName=leaf)varname=node.childNodesi.getAttribute(text);vartemp=dhtmlObject.a0Find(parentId);获取父节点对象temp.XMLload=1;已加载构造html输出节点dhtmlObject.insertItem(parentId,cId,name,im0,im1,im2,chd);dhtmlObject.addDragger=th
18、is;/设置可拖放的对象;树型结构的维护在维护树型结构表时,删除节点较为简单,SQL语句为:deletefromtree_classwhereclasscodelike,+classcode+%,,即可将其节点和孩子一并删除;增加节点时,分为前插、后插、和插入子节点三种情况,前两种情况需要更新递归更新类别代码,后者只需找到父节点的孩子的最大类别代码加1后,作为增加节点的类别代码;通过拖放来改变树的结构时,只需将拖动节点的parentId更新为目标节点的Classid即可,对应的SQL语句为:updatetree_classsetparentId=+classidTo+whereclassid=+classidFrom。3、效率分析对于树的存储一般有两种形式:二维表和链表,遍历方式一般也有深度遍历和广度遍历两种方式,遍历的时间复杂度都是O(n)。用二维表存储时,在内存中用数组的下标能准确定位节点的父节点、兄弟节点所在的数组下标。数据库中节点的定位也是准确的,但是将节点信息从数据库中读到内存中时,如果无法通
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024教师个人师德工作计划10
- 特许金融分析师考试知识积累试题及答案
- 旅游景点介绍及使用指南
- 幼儿水果绘本课件
- 2025届安徽省江南十校联考高三下学期一模历史试题(含解析)
- 特许金融分析师必考知识试题及答案
- 2024年特许金融分析师考试备考日程及答案
- 数据分析与CFA试题及答案
- 2025年四川省成都市高考英语二诊试卷
- 2024年CFA金融考试试题及答案
- 中学生乐团组建与训练分析
- DB62∕T 25-3103-2015 公路隧道防火涂料施工质量验收规程
- pantone色卡电子版U面
- DB44∕T 581-2009 广东城市绿化工程施工和验收规范
- 大气简约深蓝色商务汇报总结PPT模板课件
- 人教版一年级下册数学 6.100以内数的组成专项卷
- 中小学教育惩戒规则(试行)全文解读ppt课件
- 布鲁克纳操作手册
- ncstudiov5_4编程手册
- 建坐标系解立体几何(含解析)
- Eplan电气图纸设计规范终版
评论
0/150
提交评论