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

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

ID:33841197

大小:55.00 KB

页数:8页

时间:2019-03-01

基于ajax的动态树型结构的设计与实现_第1页
基于ajax的动态树型结构的设计与实现_第2页
基于ajax的动态树型结构的设计与实现_第3页
基于ajax的动态树型结构的设计与实现_第4页
基于ajax的动态树型结构的设计与实现_第5页
资源描述:

《基于ajax的动态树型结构的设计与实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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并不是一门新的语言或技术,它实际上是几项技术按一定的方式组合在共同的协作中发挥各自的作用,它包括:  ·使用扩展超媒体标记语言(eXtendedHypertex

4、tMarkupLanguage,简称XHTML)和级联样式单(CascadingStyleSheet,简称CSS)标准化呈现;  ·使用文档对象模型(DocumentObjectModel,简称DOM)实现动态显示和交互;  ·使用可扩展标记语言(eXtensibleMarkupLanguage,简称XML)和可扩展样式表转换(eXtensibleStylesheetLanguageTransformation,简称XSLT)进行数据交换与处理;  ·使用XMLHTTP组件XMLHttpRequest对象进行异步数据读取;  ·最后用JavaScript绑定和处理所有数据。  A

5、jax的工作原理如图1所示,它相当于在用户和服务器之间加了一个中间层,使用户操作与服务器响应异步化。并不是所有的用户请求都提交给服务器,像—些数据验证和数据处理等都交给Ajax引擎处理,只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求。这样就把一些服务器负担的工作转嫁到客户端,利用客户端闲置的处理能力来处理,减轻服务器和带宽的负担,从而达到节约ISP的空间及带宽租用成本的目的。图12、总体设计方案  传统的服务器程序采用Model1开发模型,通常将业务逻辑、服务器端处理过程和HTML代码集中在一起表示,快速完成应用开发。Model1在小规模应用开发时优势明显,

6、但是应用实现一般是基于过程的,一组服务器页面实现一个流程,如果流程改动将导致多个地方修改,非常不利于应用的扩展和更新。此外业务逻辑和表示逻辑混合在服务器页面中,耦合紧密,无法模块化,导致代码无法复用。  Model2则解决了这些问题,它是面向对象的MVC模式(Model-View-Controller,模型-视图-控制器)在Web开发中的应用,Model表示应用的业务逻辑,View是应用的表示层页面,Controller是提供应用的处理过程控制。通过这种MVC设计模式把应用逻辑,处理过程和显示逻辑划分成不同的组件、模块实现,组件间可以进行交互和重用。本方案是采用J2EE的多层架构

7、,设计时结合Struts框架将表示层、业务逻辑层和数据层划分成不同的模块。表示层专注于树的外观显示,业务逻辑层为服务器端处理程序,处理树的生成、变化,为减少耦合性,该程序全部模块化实现,不在表示页面嵌入服务器程序;模型层是数据的存储和表示。下面分别介绍各层实现。  2.1表示层实现  类似Windows资源管理器的文件夹模式,节点的图片样式如表1所示。对于每个节点的DHTML代码,需要包含节点的位置、前导图片、样式、针对该节点的其他操作等。同时为了节点显示的连贯性,还需一些前导图

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。