一种数据展示模型建立方法、数据展示方法及装置的制作方法

文档序号:6579634阅读:180来源:国知局

专利名称::一种数据展示模型建立方法、数据展示方法及装置的制作方法
技术领域
:本发明涉及计算机信息处理
技术领域
,具体地,涉及一种数据展示模型建立方法、数据展示方法及装置。
背景技术
:在web应用开发过程中,经常需要在网页上按照业务系统所要求的表单样式来展示数据,并响应最终用户的增加、删除、更改、查询等操作以及将被需要保存的数据提交到数据库中保存。这其中包含了获取数据,创建表单对象,填充数据,增加数据,删除数据,更改数据,保存改动后的数据等一系列过程。在传统的web应用开发技术中,这个过程是非常繁琐的,特别是开发RIA(RichInterfaceA卯lications,富界面应用)时,客户端脚本(Script)编码工作量大,脚本调试困难,包含大量的重复劳动。例如,如果要在web页面上展示一个表单,通常的做法是按照业务系统需要的表单样式,直接在恥b页面上用HTML元素(table、div等)组合,生成表单框架。然后调用数据库管理程序获取需要的数据,将获取到的数据依次填充到表单框架中对应的位置上。如果需要修改表单内容并保存修改后的数据,则还需要在web页面上添加相关脚本用于生成编辑控件、处理最终用户输入、提取修改后的数据并保存。服务器端也需要添加相应的代码来处理相关数据。因此现有的web应用开发过程存在开发工作量大,脚本调试困难,容易出错等问题,而且恥b页面上的表单不具备封装性,可重用性差,导致整个应用的开发效率不高。
发明内容针对现有技术存在的问题,本发明提供一种数据展示模型建立方法、数据展示方法及装置,以基于可重用的数据展示模型进行数据的展示。为了实现上述目的,本发明实施例提供一种数据展示模型建立方法,该方法包括进行数据展示模型定义,包括定义数据集及显示样式;根据所述数据展示模型定义生成数据展示模型XML(ExtensibleMarkupLanguage,可扩展标记语言)文档;将所述数据展示模型XML文档存储在服务器。本发明实施例还提供一种数据展示方法,包括向服务器发送数据展示请求;接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;根据所述数据展示模型XML文档创建表单框架;向服务器发送数据检索请求,该请求中携带所述数据集定义;接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,并将所述展示数据填充到所述表单框架中,形成表单并进行展示。本发明实施例还提供一种数据展示模型建立装置,包括定义单元,用于进行数据展示模型定义,包括定义数据集及显示样式;生成单元,用于根据所述数据展示模型定义生成数据展示模型可扩展标记语言XML文档;存储单元,用于将所述数据展示模型XML文档存储在服务器。本发明实施例还提供一种数据展示装置,包括第一发送单元,用于向服务器发送数据展示请求;第一接收单元,用于接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;创建单元,用于根据所述数据展示模型XML文档创建表单框架;第二发送单元,用于向所述服务器发送数据检索请求,该请求中携带所述数据集定义;第二接收单元,用于接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,将所述展示数据填充到所述表单框架中,形成表单;展示单元,用于展示所述表单。本发明实施例能够基于可重用的数据展示模型进行数据的展示,减少了二次开发阶段的工作量。为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。图1为本发明一实施例中数据展示模型建立方法的流程示意图;图2为本发明一实施例中在客户端进行数据展示的流程示意图;图3为本发明实施例中数据展示模型实例化对象的结构示意图;图4为本发明实施例中本地数据缓存对象的结构示意图;图5为本发明另一实施例中在客户端进行数据展示的流程示意图;图6为图5中步骤S260对应的数据修改操作流程示意图;图7为本发明实施例中数据库适配器对象的结构示意图;图8为基于DJFocus的Web开发组件来实现本发明的原理示意图;图9为本发明实施例中待展示的表单示意图;图10为本发明实施例中建立数据展示模型的界面示意图;图11为本发明实施例中通过DJFoucsDesigner设计表单的界面示意图;图12为本发明实施例中数据展示模型建立装置的结构框图;图13为本发明一实施例中数据展示装置的结构框图;图14为本发明另一实施例中数据展示装置的结构框图。具体实施例方式下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。本发明实施例提供一种建立可重用的数据展示模型的方法,并基于所建立的数据展示模型来解决传统的web应用开发技术中,客户端脚本编码工作量大,脚本调试困难,web页面上的表单不具备封装性以及可重用性差的问题,从而简化web页面的数据展示操作。本实施例中,首先建立一个数据展示模型并将其存放在服务器上,这个数据展示模型是可重用的,被封装在一个数据模型XML文档中,即该数据展示模型以XML文档形式存放在服务器上,并且不依赖于具体的恥b页面,可以被不同的web页面所调用。然后在需要展示表单的客户端的web页面上调用建好的数据展示模型,客户端会自动将数据展示模型实例化,创建表单框架,进一步通过向服务器获取作为表单数据的数据XML文档,生成表单并展示在页面上。只要在数据展示模型中定义了数据项的编辑模式和数据提交方式,上述表单的数据就可以被修改和保存,不需要额外编写相关代码。如果客户端需要提交被修改的数据时,只需要调用数据展示模型实例化对象的提交方法即可完成数据提交。本发明实施例中,建立数据展示模型的过程可在客户端完成,开发人员可通过客户端的浏览器访问数据模型设计页面,进行数据展示模型设计,数据展示模型建立完成后由客户端提交给服务器,以在服务器端保存该数据展示模型。如图1所示,本发明实施例的数据展示模型建立方法包括步骤SllO,定义数据展示模型,生成数据展示模型XML文档。本步骤中,定义数据展示模型可包括定义数据集及显示样式等。(1)定义数据集数据集用于描述当前数据展示模型如何获取数据。如果是从数据库获取数据,则定义的数据集包括SQL(StructuredQueryLanguage,结构化查询语言)查询语句、相关表(如数据库表)和列的属性定义;如果不是从数据库获取数据,则可定义扩展数据集,扩展数据集只需要定义列的属性。本发明实施例中,如果不从数据库中获取数据,该数据展示模型可被称之为"具有外部数据源的数据展示模型"。这种数据展示模型可不跟数据库交互,而只作为一个展示数据的载体。可以在页面上写脚本以向展示数据的载体中添加数据,该数据展示模型也会根据预先定义的样式和风格来展示添加的数据,但这些添加的数据不能更新到数据库中。如果需要在运行时确定检索数据的条件,则定义数据展示模型还包括定义检索参数。定义了检索参数后,可以在运行时由脚本传递参数值给数据展示模型作为检索数据的条件。所述运行时确定检索数据的条件是指在设计数据展示模型时,开发人员不能确定检索数据的条件,需要由最终用户在使用数据展示模型的时候,根据自己的需要,设置检索数据的条件,即检索参数的值。例如,如果在人员信息表中检索所有年龄大于30的人,这个"年龄大于30"就是检索数据的条件。同一个数据展示模型,既可以检索"年龄大于30"的人,也可以检索"年龄大于50"的人,因为开发人员并不是最终用户,所以并不能确定检索数据的条件,此时开发人员可以定义检索参数,最终用户可在使用数据展示模型时确定检索数据的条件,即检索参数的值。所述检索数据的条件可通过执行页面上的脚本来传递给数据展示模型。(2)定义数据展示模型的显示样式数据展示模型的显示样式可包括表单布局、编辑模式、显示格式及数据展示模型上放置的对象等;数据展示模型上放置的对象例如可为文本框、按钮、计算域、图片、文件、矩形框、线条等界面对象。在定义数据集之后,数据集所包含的列就可以作为数据展示模型的数据项来使用。根据所需要的表单布局,可指定这些数据项的分布区域和坐标值,将数据项放置到合适的位置上。分布区域包括标题区、表头区、数据区、表尾区和脚注区等。坐标值就是相对于分布区域的X,Y坐标。每个数据项可以定义不同的编辑模式和显示格式。其中,编辑模式包括数据展示模型中所定义的列对象具有的编辑模式,具体是指该列对象展示在页面上之后,以哪种方式来输入数据,例如包括手工单行输入、手工多行输入、下拉列表选择、复选框、单选框、弹出日历选择、弹出窗口选择等。显示格式包括带小数的数字、百分比、货币、日期时间、科学计数法等。除了数据项以外,数据展示模型中还可以添加文本框、按钮、计算域、图片、文件、矩形框、线条等界面对象,每个对象都可以放置在数据展示模型中的任意位置(自由式布局)或放置于网格线中(列表式布局)。其中,计算域对象必须包含一个计算表达式,计算域对象的值就是通过该表达式计算后得到的结果。在本发明具体应用中,可选地,定义数据展示模型的步骤还可以包括定义如下信息(3)定义数据分组条件。如果表单需要进行分组显示、分组小计等,则可以在数据展示模型中定义数据分组条件。数据分组支持级联分组,所谓级联分组就是指在一个分组的基础上再次分组,比如先按照人员所属部门分组,再按照性别分组。数据项和计算域都可以作为数据分组条件的元素,数据分组条件是包含至少一个上述元素的计算表达式,比如要设置数据按照人员性别分组,则表示数据分组条件的表达式为"sex"(性别的字段名为sex)。(4)定义数据排序条件。数据展示模型中定义的数据排序条件,用于对展示在客户端页面上的数据进行排序。排序方式有升序和降序两种。数据项和计算域都可以作为数据排序条件的元素,数据排序条件是包含至少一个上述元素的计算表达式。比如,要按照年龄进行排序,则设定排序表达式为"ageA"(年龄的字段名为age,A表示从小到大升序排序,降序则使用D)。(5)定义数据过滤条件。数据展示模型中定义的数据过滤条件,用于对展示在客户端页面上的数据进行过滤,符合过滤条件的数据行被显示出来,否则被隐藏。数据过滤操作在客户端完成,可以减少与服务器或数据库交互的次数。数据项和计算域都可以作为数据过滤条件的元素,数据过滤条件是包含至少一个上述元素的计算表达式,比如,要设置过滤出所有年龄大于30的记录,则过滤表达式为"age>30"(年龄的字段名为age)。(6)定义数据提交方式。数据提交方式定义了在客户端页面上展示的数据被最终用户改动之后,是否需要提交、提交哪些数据、哪几个数据项作为数据提交时的关键字。数据展示模型定义完成后,会生成一个数据展示模型XML文档。本发明一实施例中,数据展示模型XML文档的格式可如表1所示。表1.数据展示模型XML文档格式示例〈文档根节点标签>〈数据集定义标签>〈数据集SQL语句定义标签/>〈数据集表标签/>〈数据集列标签/>〈检索参数定义标签/>〈数据过滤条件标签/>〈数据排序条件标签/>〈/数据集定义标签>〈数据分组定义标签/>〈标题区定义标签/>〈表头区定义标签/>〈数据区定义标签/>〈表尾区定义标签/>〈脚注区定义标签/>〈文本对象定义标签/>〈图片对象定义标签/>〈按钮对象定义标签/>〈计算域对象定义标签/>〈矩形框对象定义标签/>〈线条对象定义标签/>〈二进制对象定义标签/>〈列对象定义标签>〈列编辑模式定义标签/>〈/列对象定义标签>〈/文档根节点标签>对于具有外部数据源的数据展示模型,数据展示模型XML文档的格式基本上与表1相同,只是在〈数据集定义标签>节点下,不包括〈数据集SQL语句定义标签/>和〈数据集表标签/>两个节点。步骤S120,向服务器提交所述数据展示模型XML文档。具体地,数据展示模型定义完成后,客户端(如通过客户端的浏览器页面脚本)会向服务器发送保存数据展示模型XML文档的请求,以请求服务器端保存所述数据展示模型XML文档。服务器端处理客户端的请求,将该数据展示模型XML文档进行保存。如果保存失败,则服务器端会返回错误信息至客户端。通过上述步骤S110S120,便完成了数据展示模型的建立。基于上述建立的数据展示模型,或者说,基于在上述过程中建立的数据展示模型8XML文档,任意与服务器连接的客户端就可以方便地在web页面上进行数据展示。进行数据展示就是获取保存在服务器上的数据展示模型XML文档和相关数据,以表单的形式将相关数据展示在客户端恥b页面上,以便最终用户查看或操作。如图2所示,本发明一实施例中,在客户端进行数据展示的流程包括步骤S210,客户端向服务器发送数据展示请求。客户端页面上如果包含了引用数据展示模型的脚本或标签,在页面被执行时,就会向服务器端发送请求,以获取指定的数据展示模型XML文档。服务器端接收到客户端页面的请求后,获取客户端页面所请求的数据展示模型名称,通过模型名称转换为数据展示模型XML文档的实际路径,然后读取文档内容。如果指定的数据展示模型XML文档被找到且能正确读取其内容,则返回数据展示模型XML文档内容到客户端;否则返回错误信息。步骤S220,接收来自服务器的数据展示模型XML文档。如果服务器端能够成功找到并读取数据展示模型XML文档的内容,则服务器端会返回数据展示模型XML文档内容到客户端,此时客户端会接收到来自服务器的数据展示模型XML文档。步骤S230,解析所述数据展示模型XML文档,创建数据展示模型实例化对象,在web页面上展示该数据展示模型实例化对象的表单框架并创建本地数据缓存对象。数据展示模型XML文档中定义的信息不能直接在网页上显示,而是通过数据展示模型实例化对象来展示。客户端接收到来自服务器端的数据展示模型XML文档后,通过页面脚本调用相应的解析引擎解析所述数据展示模型XML文档,创建数据展示模型实例化对象。数据展示模型实例化对象是一个界面对象,数据展示模型实例化对象不仅可以用于展示数据展示模型所定义的外观和属性,还可以根据数据展示模型创建数据操作的方法和事件,并响应最终用户的各种操作和事件,即具备界面交互能力。比如最终用户想添加一行新数据,则调用实例化对象的创建的"添加行"方法,上述实例化对象的"添加行"方法负责实现具体的添加操作;在响应事件方面,比如用户在某一个数据项上按下Tab键,则上述实例化对象自动将输入焦点跳转到下一个数据项。图3为本发明实施例的数据展示模型实例化对象的结构示意图,描述如下数据展示模型实例化对象可包括三个子对象数据定义对象、数据视图对象和数据操作对象。其中数据定义对象负责解析数据展示模型XML文档,存储数据展示模型XML文档中的各种定义;数据视图对象用于读取数据定义对象中的各种定义,并按照各定义所描述的风格在web页面上创建表单框架和填充数据;数据操作对象不依赖于具体的数据展示模型,可为任何数据展示模型的实例对象创建数据操作所需要的方法和事件,其中所述数据操作可包括提交、增加、删除、修改、查询等,但并不限于此。针对该数据展示模型实例化对象,客户端根据数据展示模型XML文档中定义的表单布局、界面对象等显示样式信息,在客户端页面上创建相应的网页元素并设置其属性(如宽度、高度、颜色、字体等),以达到预期的界面效果。此时生成的界面网页元素不包括数据,只包括表单框架。客户端页面脚本在创建好表单框架后,还会自动创建一个本地数据缓存对象。本地数据缓存对象驻留在客户端内存中,刚创建的本地数据缓存对象中并不包含数据。客户9端可通过向本地数据缓存对象中添加数据,要向数据缓存对象中增加数据有两种途径(1)向服务器检索数据并获取数据XML文档,解析数据XML文档,将数据按照行列添加到本地数据缓存对象中;(2)调用数据展示模型实例化对象增加数据的相关方法或事件,将数据行添加到本地数据缓存对象中,并设置列数据值。设置列数据值是设置添加的新行中所包含的若干列的值。一行数据包含若干列,每个列有一个数据值。本实施例中,本地数据缓存对象的格式示意如图4所示。本地数据缓存对象可按行存储数据,每行包括"行修改状态"和"数据列集合"。其中行修改状态包括未修改、新增加、被修改(即被替换)、被删除等。数据列集合由若干数据列对象组成。每个数据列对象包括"列修改状态"和"列数据值"。列修改状态包括未修改、被修改。列数据值包括原始值、修改后的值、是否为空。从上述结构可以看出,无论是新增加、删除还是替换的数据,并没有立即提交到服务器端进行处理,而是保存在本地数据缓存对象中,就相当于本地有一个数据集合,任何数据操作都是在这个数据集合上进行。当数据操作完成后,发出提交数据的请求时,再统一向服务器提交这些数据。本地数据缓存相当于一个本地的临时数据存储容器,客户端页面对数据的读写操作都在这个数据存储容器中进行,不必每次都访问服务器。等客户端操作完成之后,再一次性提交到服务器,因此使用本地数据缓存对象可以减少客户端页面与服务器端交互的次数。同时,因为每次访问的数据都是在本地计算机内存中的对象,没有网络延迟和磁盘读写,所以还能提高页面响应速度。步骤S240,向服务器发送数据检索请求,该数据检索请求中携带数据展示模型的数据集定义。客户端页面如果需要检索数据,即进行查询操作,则可通过客户端脚本向服务器端发送检索数据的请求。此时,客户端脚本将数据展示模型的数据集定义部分发送到服务器端,数据集定义包含了获取数据的规则。服务器端响应数据检索请求,并解析接收到的数据集定义,按照数据集定义中的数据获取规则从数据库中获取数据,例如在数据库中执行数据集定义中的SQL语句,得到一个结果集,其中可包含数据集定义所描述的数据库表中的数据。如果成功获取到数据(结果集),则服务器端将获取的数据组合成一个XML格式的文档,即数据XML文档,并返回给客户端页面;否则,向客户端返回错误信息。客户端检索数据的时候,如果数据展示模型设置了检索参数定义,需要客户端脚本提供检索参数的值。此时,客户端脚本将数据展示模型的数据集定义部分连同检索参数的值一起发送到服务器端。所述数据XML文档的格式可如表2所示表2.数据XML文档格式示例〈文档根节点标签>〈事务信息标签>〈执行结果代码/>〈执行结果描述/>〈/事务信息标签>〈数据集标签>〈数据行标签>〈列标签>数据〈/列标签>〈/数据行标签>〈/数据集标签>〈/文档根节点标签>步骤250,接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,将所述展示数据填充到所述表单框架中,形成表单并进行展示。客户端接收到服务器端返回的数据XML文档,调用数据解析引擎解析所述数据XML文档,并将解析后获得的展示数据添加到本地数据缓存对象中。客户端脚本将当前需要展示在页面上的展示数据从本地数据缓存对象中提取出来,填充到客户端页面上创建好的表单框架中,形成完整的表单,从而可通过表单实现客户端页面的数据展示。实现客户端页面的数据展示之后,本地数据缓存对象将被保留在客户端内存中,用户可以以本地数据缓存对象为基础对数据进行数据修改等操作,数据修改操作又可包括增加、删除、替换等操作。下面对数据操作过程进行详细的说明。如图5所示,数据展示流程中的后续数据操作还包括如下步骤步骤S260,对表单中的数据进行修改操作,对修改后的数据设置修改状态标识并存储所述修改后的数据。数据修改操作可改变上述创建好的表单中的数据。具体地,如图6所示,数据修改操作的类型例如可分为增加数据、删除数据和替换数据。其中增加数据是按照数据展示模型定义中描述的数据行的结构来添加新的数据行。客户端脚本执行增加数据的脚本后,将新添加的数据行写入到本地数据缓存对象中,并设置该数据行的状态为"新增"。删除数据是将本地数据缓存对象中要删除的数据行的状态设置为"删除"。如果该数据行是当前页面上展示的数据,则同时从页面上删除。替换数据是客户端页面脚本将新的数据行写入到本地数据缓存对象中相应的位置,替换原有的数据行,并设置该新的数据行的状态为"替换"。执行增加、删除或替换等修改操作之后,本地数据缓存对象也被修改,原始的数据和修改后的数据都被记录在本地数据缓存对象中。如果需要向服务器端提交修改后的数据,则本发明实施例可进一步包括如下步骤步骤S270,提取所述修改后的数据,生成数据变更XML文档。如果需要提交这些被改动的数据,客户端可以调用数据展示模型实例化对象的数据提交方法,该方法可自动遍历本地数据缓存对象,把被改动的数据提取出来,形成一个记录数据改动情况的数据变更XML文档。数据变更XML文档的格式可如表3所示。表3.数据变更XML文档格式〈文档根节点标签>〈数据集定义标签>〈数据集SQL语句定义标签/>〈数据集表标签/>〈数据集列标签/>〈/数据集定义标签>〈数据改动记录集标签>〈数据增加记录集标签>〈增加的行/>〈/数据增加记录集标签>〈数据替换记录集标签>〈替换的行/>〈/数据替换记录集标签>〈数据删除记录集标签>〈删除的行/>〈/数据删除记录集标签>〈/数据改动记录集标签>〈/文档根节点标签>步骤280,向服务器提交数据更新请求和所述数据变更XML文档,以使所述服务器更新数据库中的数据。该数据变更XML文档以及数据更新请求可被一起提交到服务器端,服务器端会处理所述数据更新请求,并解析所述数据变更XML文档,利用所述数据变更XML文档更新当前数据库中的数据,例如,更新数据集定义所描述的数据库表中的数据。如果更新失败可返回错误信息,如果更新成功可向客户端返回成功信息及更新的记录数(该记录数表示一次添加、删除或替换了多少条记录)。由于服务器端管理数据库的数据库管理系统有可能是不同类型的数据管理系统,而每种数据库管理系统的语法都有所差别,因此本发明实施例还提供一种数据库适配器对象,以适应不同的数据库管理系统。具体地,可由数据库适配器对象根据不同的数据库管理系统,生成适合当前数据库的批量更新数据库的命令并执行所述命令。若执行命令失败可返回错误信息;执行命令成功可返回成功信息和更新的记录数。本发明实施例中,数据库适配器对象是一个Java类对象,其结构示意可如图7所示。图7中,数据库适配器对象为每个数据库管理系统提供了一个适配接口,每个接口与对应的数据库驱动程序交互,数据库驱动程序由数据库管理系统厂家提供。每个适配接口负责处理特定数据库的语法,为外部12程序提供一个统一的数据操作接口。数据检索、数据更新等数据操作的方法都是以这个统一的数据操作接口为基础。数据库适配对象可以增强外部程序的数据库无关性。本发明实施例中,数据展示模型的建立方法及对应的数据展示方法可以基于多种web开发组件来实现,例如可以基于DJFocus的web开发组件来实现,但本发明并不限于此,其他目前用于web页面开发的组件也同样适用于本发明。其中DJFocus是一个基于Java的web开发组件,程序开发人员可借助DJFocus快速开发web应用。如图8所示,DJFocus可分两部分来实现本发明,一部分是服务器端代码(包括TagLib、Serlvet和JavaBean等),另一部分是在客户端页面中运行的Script脚本。本实施例中,采用DJFocus的具体实现步骤例如可为第一步,创建数据展示模型。这个可以通过DJFocus提供的设计器(Designer)进行设计,也可以手工创建一个XML文档,按照表1所规定的格式输入数据展示模型的定义,并将这个XML文档保存在服务器上。第二步,根据数据展示模型创建数据展示模型实例化对象。开发人员可通过在客户端页面上的TagLib标签调用TagLib服务器端程序,TagLib服务器端程序通过调用相关的JavaBean,并将服务器端的信息返回到客户端页面,这部分程序用于在客户端页面上创建数据展示模型实例化对象。第三步,调用数据展示模型实例化对象的方法和事件。通过客户端页面上的Script脚本引用DJFocus客户端代码,DJFocus客户端代码通过AJAX技术提交客户端请求到服务器端Servlet程序。DJFocus服务器端Servlet程序接收到客户端的请求后,调用相关的JavaBean或者通过JavaBean调用数据库适配器从数据库获取数据,并将处理结果返回到客户端页面,从而实现数据的展示。从上述过程可以看出,传统技术中在web页面上用HTML组合表单的过程被本发明的数据展示模型的建立和数据展示过程所替代;并且传统技术中在恥b页面上编写Script脚本处理数据修改的过程被封装到本发明的数据展示模型实例对象中,不需要额外编写代码。以下通过一个在网页上展示表单数据的例子来说明发明的效果。图9是要展示一个最基本的列表式表格。要实现如图9所示的展示,要求从数据库表person」nfo中取出4个字段的数据并展示,这4个字段分别为id(标识,例如可为编号),name(姓名),sex(性别)及age(年龄),其中sex字段根据代码"1"或者"0"显示"男"还是"女"。图9所示的表格中,要求每个数据项的数据可编辑,并能增加、删除和保存数据。下面分别在硬件软件环境完全一样的情况下,通过采用传统技术和采用本发明的数据展示方法来体现本发明的有益效果。本实施例中,采用的软件平台是基于DJFocus的Web开发组件。(l)采用传统技术采用传统技术,开发人员需要写两个页面数据展示页面normal—showData.jsp和数据保存页面normal_saveData.jsp,这两个页面的脚本代码见表4。去掉jsp和HTML页面所必需的代码外,用于数据展示和操作的脚本代码共计195行。表4.normal—showData.jsp禾口normal—saveData.jsp的展卩本代码<table>tableseeoriginaldocumentpage14</column></row><table><table>tableseeoriginaldocumentpage15</column></row><table><table>tableseeoriginaldocumentpage16</column></row><table>cell=row.insertCell0;oSelect=cell.appendChild(document.createElement("<select>"));oSelect.onfocus=function0{—curRow=row.rowlndex;};〃设置性别的下拉选择项oOption=document.createElement("<option>");oOption.value="1";oOption.text="男";oSelect.options.add(oOption);oOption=document.createElement("<option>");oOption.value="0";oOption.text="女";oSelect.options.add(oOption);〃设置第五列年龄cell=row.insertCell0;ol叩ut=cell.appendChild(document.createElement("<inputtype=text>"ol叩ut.style.textAlign="right";ol叩ut.onfocus=function0{this.select0;—curRow=row.rowlndex;〃删除按钮点击事件functionbtnDelete.onclickO{if(_curRow<l)return;〃将被删除行的关键字段的值保存到数组中if(dataTable.rows[_curRow]■cells[1]■firstChild.DBValue){—deletedRow.push(dataTable.rows[—curRow].cells[l].firstChild.DBValue):}〃删除表单中的行dataTable.deleteRow(—curRow);〃设置当前行if(—curRow==dataTable.rows,length)—curRow--;if(dataTable.rows.length>l){if(—curRowKl)CurRow=1;dataTable.rows[—curRow].cells[1].firstChild.focus0;〃设置行的序号for(vari=1;i<dataTable.rows,length{dataTable.rows[i].cells.innerHTML=i;CN101788994A眾s步14/24X<table>tableseeoriginaldocumentpage18</column></row><table><image>imageseeoriginaldocumentpage19</image>(2)采用本发明的数据展示方法若采用本发明来实现图9的展示效果,则是先用DJFocus设计器进行可视化数据展示模型设计,建立数据展示模型。然后基于建立的数据展示模型进行数据的展示。基于DJFocus的web开发组件实现图9所示的展示的步骤举例如下第一步开发人员在DJFocus设计器中选择"新建模型",在弹出的新建窗口中,根据需要展现的表格和数据库表的字段信息,确定表单展示风格和SQL查询语句,然后创建一个名为personList.xml的XML文档,此时所创建的XML文档就是数据展示模型XML文档,该文档保存在服务器上。图10为通过DJfocus设计器新建一个名为personList.xml的数据展示模型的界面示意图。0132]上述数据展示模型中,数据集定义可如下〈datasource>〈sqlselect>selectid,name,sex,agefromperson_info〈/sqlselect>〈tabletype=〃table">person_info〈/table>〈coltableid=ltype=〃NUMBER"precision=〃6〃scale=〃0〃>id〈/0133]0134]0135]0136]col>0137]0138]0139]0140]0141]〈coltableid=1type=〃VARCHAR">name〈/col>〈coltableid=1type=〃CHAR">sex〈/col>〈coltableid=1type=〃NUMBER">age〈/col>〈/datasource>上述数据集定义包含了4个列id,name,sex,age。这些列可以作为数据展示的数据项,放置在数据展示模型中指定的位置上,用来展示从数据库中检索出来的数据。0142]第二步打开创建的数据展示模型XML文档,进行模型的属性设置。0143]在第一步创建模型时,使用的基本上都是默认的属性,这些属性通常不能完全满足需求,所以要在第二步进行详细的设置。具体地,DJFocus组件可通过一个设计器画板打开创建的数据展示模型XML文档,自动生成一个初始的表格样式,开发人员在此基础上进一步设置表格的各种属性,即进行数据展示模型XML文档的编辑,比如设置表格标题栏的背景、数据项字体、颜色等等。图11为通过DJFoucsDesigner设计表单的界面示意图。设置完成之后,保存数据展示模型XML文档。保存的数据展示模型XML文档示例如表5所示。表5.数据展示模型XML文档示例20<table>tableseeoriginaldocumentpage21</column></row><table><table>tableseeoriginaldocumentpage22</column></row><table>第三步使用数据展示模型XML文档。开发人员在客户端页面上利用标签库TagLib标签,引用数据展示模型,DJFocus组件会根据所引用的数据展示模型在客户端页面上创建相应的数据展示模型实例化对象,并同时创建三个子对象数据定义对象、数据视图对象和数据操作对象。数据定义对象负责解析XML文档中的各个定义节点,然后由数据视图对象来负责展示。数据操作对象负责加载操作所需要的方法和事件。此时,还会创建本地数据缓存对象,但此时不填充具体的数据。第四步检索数据。开发人员通过客户端Script脚本调用检索数据的方法,数据展示模型实例化对象则向服务器端发送检索数据的请求,服务器端Servlet程序接收到请求之后,调用相应的JavaBean,JavaBean程序通过数据库适配器从数据库中获取到所需要的数据,并通过Servlet返回给客户端页面。此时,返回的数据就是以数据XML文档的形式返回的。返回的数据XML文档示例如表6所示。表6.数据XML文档格式示例〈?xmlversion=〃1.0〃?>〈xmldata>〈transinfo>〈code>0〈/code>〈dbcode>0〈/dbcode>〈message>〈/message>〈retrievedrows>3〈/retrievedrows>〈/transinfo>〈dataset>〈r>〈c>001〈/c>〈c>张三〈/c>〈c>0〈/c>〈c>36〈/c>〈/r>〈r>〈c>002〈/c>〈c>李四〈/c>〈c>l〈/c>〈c>38〈/c>〈/r>〈r>〈c>003〈/c>〈c>王五〈/c>〈c>l〈/c>〈c>42〈/c>〈/r>〈/dataset>〈/xmldata>23第五步展示数据。客户端页面中的数据展示模型实例化对象接收到服务器端返回的数据XML文档后,将数据填充到本地数据缓存对象中,并同时把当前需要显示的数据填充到页面上的表单框架中,形成的表单如图9所示。第六步数据操作。展示在页面上的数据展示模型实例化对象是一个可交互的界面对象。数据展示模型实例化对象可调用各种方法(查询、增加、删除、替换、保存等)来实现与最终用户的交互,并可更新展示交互后的结果。当操作完成之后需要提交时,就要使用数据变更XML文档。数据变更XML文档可将本地交互所产生的数据变更按照增加、删除、替换进行分类汇总。上述数据变更XML文档通过客户端Script脚本采用AJAX技术与服务器端Servlet程序通信,提交数据变更XML文档到服务器端。服务器端通过Servlet程序调用JavaBean和数据库适配器,将数据变更提交到数据库中。然后通过Servlet返回本次提交是否成功的信息。客户端页面接收到服务器的返回信息后,提示最终用户本次操作是否成功。数据操作后生成的数据变更XML文档的示例如表7所示。表7.数据变更XML文档示例24<xmlversion="1.0"><xmldata><datasource><sqlselect>selectID,NAME,SEX,AGEfromPERSON—INFOorderbyid</sqlselect><tableschema="DPSUSER"type="TABLE"update="yes">person—info</column></row><table><colcoltype="string"type="CHAR"nullable="no"precision="3"scale="0"tableid="1"update="yes"key="yes">id</col><colcoltype="string"type="CHAR"nullable="no"precision="10"scale="0"tableid="1"update="yes"key="no">name</col><colcoltype="string"type="CHAR"nullable="no"precision="1"scale="0"tableid="1"update="yes"key="no">sex</col><colcoltype="number"type="NUMBER"nullable="no"precision="5"scale="0tableid="1"update="yes"key="no">age</col></datasource><updatelist><deletedrow><r><pk>003</pk></r></deletedrow><updatedrow><r><c>002</c><cs="1"0="李四"n="0"〉李四l〈/c〉<c>l</c><cs="1"o="38"n="0">33</c></r></updatedrow><insertedrow><r><cs="2"n="0">005</c><CS="2"n="0"〉赵六〈/c〉<cs="2"n="0">0</c><cs="2"n="0">32</c></r></insertedrow></updatelist>:/xmldata>本实施例中基于DJFocus来实现图9所展示的表格的的脚本代码如表8所示。在页面上调用表8所示的脚本代码,去掉jsp和HTML页面所必需的代码外,用于数据展示和操作的脚本代码共计18行,代码行数不到传统方式的十分之一。表8.基于DJFocus来实现图9所展示的表格的代码25<table>tableseeoriginaldocumentpage26</column></row><table>效率并减少脚本出错的机率。本发明实施例还提供一种数据展示模型建立装置,如图12所示,该装置包括定义单元1201,用于进行数据展示模型定义,包括定义数据集及显示样式;生成单元1202,用于根据所述数据展示模型定义生成数据展示模型可扩展标记语言XML文档;存储单元1203,用于将所述数据展示模型XML文档存储在服务器。在具体应用中,所述定义单元1201还用于定义数据展示模型中如下信息中的一项或多项数据分组条件、数据排序条件、数据过滤条件及数据提交方式。本实施例提供的数据展示模型建立装置可以为客户端或客户端的一部分,可用于实现前述的数据展示模型建立方法。本发明实施例还提供一种数据展示装置,如图13所示,该数据展示装置1300包括第一发送单元1301,用于向服务器发送数据展示请求;第一接收单元1302,用于接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;创建单元1303,用于根据所述数据展示模型XML文档创建表单框架;第二发送单元1304,用于向所述服务器发送数据检索请求,该请求中携带所述数据集定义;解析弓|擎1305,用于接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,并将所述展示数据填充到所述表单框架中,形成表单并进行展示;展示单元1306,用于展示所述表单。在本发明具体应用中,该装置还可包括修改单元1307,用于对表单中的数据进行修改,并对修改后的数据设置修改状态标识。提取单元1308,用于提取所述修改后的数据,生成数据变更XML文档;提交单元1309,用于向所述服务器提交所述数据变更XML文档,以使所述服务器更新数据库。本发明实施例提供的数据展示装置为客户端或客户端的一部分,可用于实现前述实施例中的数据展示方法。本领域普通技术人员可以理解实现上述实施例方法中的全部或部分步骤可以通过程序来指令相关的硬件来完成,该程序可以存储于一计算机可读取存储介质中,比如ROM/RAM、磁碟、光盘等。以上所述的具体实施例,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施例而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。权利要求一种数据展示方法,其特征在于,包括向服务器发送数据展示请求;接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;根据所述数据展示模型XML文档创建表单框架;向服务器发送数据检索请求,该请求中携带所述数据集定义;接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,将所述展示数据填充到所述表单框架中,形成表单并进行展示。2.根据权利要求1所述的方法,其特征在于,还包括创建本地数据缓存对象,并存储所述数据XML文档至本地数据缓存对象。3.根据权利要求1所述的方法,其特征在于所述数据展示模型还包括如下信息中的一项或多项检索参数定义、数据分组定义、数据排序定义、数据过滤定义以及数据提交方式定义。4.根据权利要求l所述的方法,其特征在于,还包括对表单中的数据进行修改,对修改后的数据设置修改状态标识并进行存储。5.根据权利要求4所述的方法,其特征在于,所述对表单中的数据进行修改包括增加、删除或替换表单中的数据。6.根据权利要求4或5所述的方法,其特征在于,还包括提取所述修改后的数据,生成数据变更XML文档;向所述服务器提交所述数据变更XML文档,以使所述服务器更新数据集定义中描述的数据库表。7.根据权利要求1所述的方法,其特征在于所述显示样式定义包括如下定义中的一项或多项表单布局定义、编辑模式定义、显示风格定义及界面对象定义。8.—种数据展示模型建立方法,其特征在于,包括进行数据展示模型定义,包括定义数据集及显示样式;根据所述数据展示模型定义生成数据展示模型可扩展标记语言XML文档;将所述数据展示模型XML文档存储在服务器。9.根据权利要求8所述的方法,其特征在于,所述进行数据展示模型定义还包括定义如下信息中的一项或多项检索参数定义、数据分组条件、数据排序条件、数据过滤条件及数据提交方式。10.根据权利要求8所述的方法,其特征在于所述显示样式包括如下信息中的一项或多项表单布局、编辑模式、显示风格及界面对象。11.一种数据展示装置,其特征在于,包括第一发送单元,用于向服务器发送数据展示请求;第一接收单元,用于接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;创建单元,用于根据所述数据展示模型XML文档创建表单框架;第二发送单元,用于向所述服务器发送数据检索请求,该请求中携带所述数据集定义;解析引擎单元,用于接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,并将所述展示数据填充到所述表单框架中,形成表单;展示单元,用于展示所述表单。12.根据权利要求11所述的装置,其特征在于,还包括修改单元,用于对表单中的数据进行修改,并对修改后的数据设置修改状态标识。13.根据权利要求11所述的装置,其特征在于,还包括提取单元,用于提取所述修改后的数据,生成数据变更XML文档;提交单元,用于向所述服务器提交所述数据变更XML文档,以使所述服务器更新数据集定义中描述的数据库表。14.一种数据展示模型建立装置,其特征在于,包括定义单元,用于进行数据展示模型定义,包括定义数据集及显示样式;生成单元,用于根据所述数据展示模型定义生成数据展示模型可扩展标记语言XML文档;存储单元,用于将所述数据展示模型XML文档存储在服务器。15.根据权利要求14所述的装置,其特征在于,所述定义单元还用于定义数据展示模型中如下信息中的一项或多项检索参数定义、数据分组条件、数据排序条件、数据过滤条件及数据提交方式。全文摘要本发明提供一种数据展示模型建立方法、数据展示方法及装置,所述数据展示模型建立方法包括向服务器发送数据展示请求;接收来自服务器的数据展示模型可扩展标记语言XML文档,该数据展示模型XML文档包括数据集定义以及显示样式定义;根据所述数据展示模型XML文档创建表单框架;向服务器发送数据检索请求,该请求中携带所述数据集定义;接收来自服务器的数据XML文档,解析所述数据XML文档获得展示数据,将所述展示数据填充到所述表单框架中,形成表单并进行展示。文档编号G06F17/30GK101788994SQ20091016278公开日2010年7月28日申请日期2009年8月14日优先权日2009年8月14日发明者朱智翔,杨俊松,杨秋申请人:成都迪捷信息技术有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1