CN105320776B - 一种基于WebApp的数据处理方法和系统 - Google Patents

一种基于WebApp的数据处理方法和系统 Download PDF

Info

Publication number
CN105320776B
CN105320776B CN201510779221.8A CN201510779221A CN105320776B CN 105320776 B CN105320776 B CN 105320776B CN 201510779221 A CN201510779221 A CN 201510779221A CN 105320776 B CN105320776 B CN 105320776B
Authority
CN
China
Prior art keywords
module
content
data
unit
root
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201510779221.8A
Other languages
English (en)
Other versions
CN105320776A (zh
Inventor
孔雷
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Guangzhou Youshi Technology Touchplus Information Corp
Original Assignee
Guangzhou Youshi Technology Touchplus Information Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Guangzhou Youshi Technology Touchplus Information Corp filed Critical Guangzhou Youshi Technology Touchplus Information Corp
Priority to CN201510779221.8A priority Critical patent/CN105320776B/zh
Publication of CN105320776A publication Critical patent/CN105320776A/zh
Application granted granted Critical
Publication of CN105320776B publication Critical patent/CN105320776B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking

Abstract

本发明公开了一种基于WebApp的数据处理方法和系统,方法包括以下步骤:步骤1、路由解释器接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;步骤2、根控制器根据hash值加载目标内容模块,并进入逻辑处理步骤;步骤3、根控制器将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中。本发明应用于由模块化开发框架所开发的应用程序中,解决应用程序中的模块复用性差、移植性差以及开发难度大的问题。

Description

一种基于WebApp的数据处理方法和系统
技术领域
本发明涉及一种基于WebApp的数据处理方法和系统。
背景技术
Web App是运行于网络和标准浏览器上,基于网页技术开发实现特定功能的应用。它是一个针对Iphone、Android优化后的web站点,它使用的客户端技术是HTML5、CSS3、JavaScript,服务端技术可以是JAVA、PHP、.net等。
单页面应用是webapp实现的一种方式,它旨在提供一个流畅的优雅的用户体验,但本身并不包含开发架构。技术人员并没有一个统一的规范去实现单页面应用,而且单页应用的特点导致大量代码(主要是html)编写在一个文件里,往往代码高度耦合、维护性差、移植性差。目前webapp并没有成熟的开发框架,导致开发人员开发效率低下,一个应用产生大量的代码,往往高耦合、难以重用,代码维护成本非常大。
发明内容
为了克服现有技术的不足,本发明的目的在于提供一种基于WebApp的数据处理方法和系统,应用于由模块化开发框架所开发的应用程序中,解决应用程序中的模块复用性差、移植性差以及开发难度大的问题。
为解决上述问题,本发明所采用的技术方案如下:
方案一:
一种基于WebApp的数据处理方法,包括以下步骤:
步骤1、路由解释器接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
步骤2、根控制器根据hash值加载目标内容模块,并进入逻辑处理步骤;
步骤3、根控制器将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中。
优选的,在步骤2中,逻辑处理步骤包括:
步骤21、将根控制器加载的目标内容模块记为当前内容模块;
步骤22、加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
步骤23、判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将其它内容模块记为当前内容模块并执行步骤22,否则执行步骤24;
步骤24、生成结果视图数据,结果视图数据用于填充至根视图模块中。
优选的,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;
和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;
和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;
和/或将获取的数据发送至其它内容模块中;
和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。
方案二:
一种基于WebApp的数据处理系统,包括以下模块:
监听模块,设于路由解释器中,用于接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
加载模块,设于根控制器中,用于根据hash值加载目标内容模块,并进入逻辑处理模块;
填充返回模块,设于根控制器中,用于将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中。
优选的,在加载模块中,逻辑处理模块包括:
标记单元,用于将根控制器加载的目标内容模块记为当前内容模块;
逻辑执行单元,用于加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
判断单元,用于判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将所述其它内容模块记为当前内容模块并执行逻辑执行单元,否则执行处理结果单元;
处理结果单元,用于生成结果视图数据,结果视图数据用于填充至根视图模块中。
优选的,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;
和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;
和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;
和/或将获取的数据发送至其它内容模块中;
和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。
相比现有技术,本发明的有益效果在于:1、内容模块之间可嵌套使用,完成一个应用可以多个内容模块相对独立地进行开发,而且每个内容模块中有固定的开发框架,由各个不同的单元组成一个内容模块,有利于开发者的团队开发,每人负责一部分,最终的应用就是通过在每个内容模块中的逻辑控制单元中定义好逻辑内容即可把各个内容模块中的单元串联起来。2、在每个内容模块中的逻辑控制单元既可通过调用本内容模块中的数据层单元获取数据,也能调用其它内容模块中的数据层单元获取数据,还可以是由其它内容模块中的逻辑控制单元将数据传入,因此数据的调用获取方式十分灵活。3、每个内容模块中的单元均可复用,可移植,每个单元之间有效地隔离,对于开发人员来说,修改内容模块中的结构也更加容易。
附图说明
图1为本发明的基于WebApp的数据处理方法的流程图。
具体实施方式
下面,结合附图以及具体实施方式,对本发明做进一步描述:
参考图1,本发明公开了一种基于WebApp的数据处理方法,包括以下步骤:
步骤1、路由解释器接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
步骤2、根控制器根据hash值加载目标内容模块,并进入逻辑处理步骤;
步骤3、根控制器将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中。
其中,内容模块包括:视图单元、逻辑控制单元、事件单元、数据层单元和显示模板单元。内容模块中的每个单元均可独立开发,对于开发者能够进行明确的分工,各自负责不同的部分,而且内容模块中的各个单元可复用、可移植,灵活性高,能够组合出不同的内容模块。逻辑控制单元的作用是响应用户端的指令,然后执行其中的相关逻辑内容,其中,响应用户端的指令可通过在视图单元中绑定事件单元中的事件实现。通过逻辑控制单元中的逻辑内容还可以实现内容模块的嵌套,完成更复杂的应用。视图单元的作用是由逻辑控制单元完成逻辑处理后将得到的数据填充至视图单元,具体的,得到的数据结合显示模板单元再填充至视图单元,形成视图数据。另外,内容模块中并不一定需要包括上述的每个单元,根据不同的需求可以选择开发不同的单元,但是逻辑控制单元是支撑内容模块的基本单元,因此是必须的。
在步骤2中,逻辑处理步骤包括:
步骤21、将根控制器加载的目标内容模块记为当前内容模块;
步骤22、加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
步骤23、判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将其它内容模块记为当前内容模块并执行步骤22,否则执行步骤24;
步骤24、生成结果视图数据,结果视图数据用于填充至根视图模块中。
其中,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;和/或将获取的数据发送至其它内容模块中;和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。当然,逻辑内容并不限定于上述的描述,还可以是根据实际需要开发不同的逻辑内容。
下面以具体的例子结合上述的方法作进一步描述:
基于一个评论页面的应用,其中包括两个内容模块,一个是评论内容模块,另一个是评论列表模块。首先在用户端中,以浏览器为例,其传递至路由解释器中的url为:http://xxx.com/index#commentList,其中,commentList为hash值,与评论列表模块对应。则根控制器根据hash值加载目标内容模块,即加载评论列表模块,从而进入评论列表模块中的逻辑处理步骤。
在步骤21中,将评论列表模块记为当前内容模块。在步骤22中,加载其中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容。在本例子中,需要通过评论内容模块中的数据层单元获取评论列表数据,因此在评论列表模块的逻辑控制单元中调用评论内容模块中的数据层单元获取评论列表数据。
在步骤23中,判断当前内容模块中的逻辑内容是否包括加载其它内容模块的逻辑,是则进入所述其它内容模块中执行其中的逻辑内容;在本例子中,评论内容模块即为评论列表模块中的其它内容模块,而在评论内容模块中定义的逻辑是循环加载评论内容模块,每一次循环则将获取的评论列表数据中的一条评论数据传入评论内容模块中的逻辑控制单元,则评论内容模块中的逻辑控制单元中的逻辑内容是:利用接收到的评论数据结合评论内容模块中的显示模板单元生成模板格式数据,并将模板格式数据填充至评论内容模块中的视图单元中。例如,评论列表数据中包括十条评论数据,则循环加载十次评论内容模块中的逻辑控制单元,从而得到一个具有十条模板格式数据的视图数据,可理解为结果视图数据。最终把结果视图数据填充至根视图模块中,由根控制器将根视图模块的内容返回浏览器中呈现给用户。
结合上述例子,本发明的的数据处理过程体现出了:1、内容模块之间可嵌套使用,完成一个应用可以多个内容模块相对独立地进行开发,而且每个内容模块中有固定的开发框架,由各个不同的单元组成一个内容模块,有利于开发者的团队开发,每人负责一部分,最终的应用就是通过在每个内容模块中的逻辑控制单元中定义好逻辑内容即可把各个内容模块中的单元串联起来。2、在每个内容模块中的逻辑控制单元既可通过调用本内容模块中的数据层单元获取数据,也能调用其它内容模块中的数据层单元获取数据,还可以是由其它内容模块中的逻辑控制单元将数据传入,因此数据的调用获取方式十分灵活。3、每个内容模块中的单元均可复用,可移植,每个单元之间有效地隔离,对于开发人员来说,修改内容模块中的结构也更加容易。
对应于上述的数据处理方法,本发明还公开了一种基于WebApp的数据处理系统,包括以下模块:
监听模块,设于路由解释器中,用于接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
加载模块,设于根控制器中,用于根据hash值加载目标内容模块,并进入逻辑处理模块;
填充返回模块,设于根控制器中,用于将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中。
优选的,在加载模块中,逻辑处理模块包括:
标记单元,用于将根控制器加载的目标内容模块记为当前内容模块;
逻辑执行单元,用于加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
判断单元,用于判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将所述其它内容模块记为当前内容模块并执行逻辑执行单元,否则执行处理结果单元;
处理结果单元,用于生成结果视图数据,结果视图数据用于填充至根视图模块中。
优选的,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;
和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;
和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;
和/或将获取的数据发送至其它内容模块中;
和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。
对本领域的技术人员来说,可根据以上描述的技术方案以及构思,做出其它各种相应的改变以及形变,而所有的这些改变以及形变都应该属于本发明权利要求的保护范围之内。

Claims (4)

1.一种基于WebApp的数据处理方法,其特征在于,包括以下步骤:
步骤1、路由解释器接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
步骤2、根控制器根据hash值加载目标内容模块,并进入逻辑处理步骤;
步骤3、根控制器将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中;
在步骤2中,逻辑处理步骤包括:
步骤21、将根控制器加载的目标内容模块记为当前内容模块;
步骤22、加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
步骤23、判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将所述其它内容模块记为当前内容模块并执行步骤22,否则执行步骤24;
步骤24、生成结果视图数据,结果视图数据用于填充至根视图模块中。
2.根据权利要求1所述的基于WebApp的数据处理方法,其特征在于,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;
和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;
和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;
和/或将获取的数据发送至其它内容模块中;
和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。
3.一种基于WebApp的数据处理系统,其特征在于,包括以下模块:
监听模块,设于路由解释器中,用于接收浏览器发起的页面请求,根据页面请求中的url获取hash值,并将hash值发送至根控制器中;
加载模块,设于根控制器中,用于根据hash值加载目标内容模块,并进入逻辑处理模块;
填充返回模块,设于根控制器中,用于将逻辑处理步骤后生成的结果视图数据填充至根视图模块中,并将根视图模块的内容返回浏览器中;
在加载模块中,逻辑处理模块包括:
标记单元,用于将根控制器加载的目标内容模块记为当前内容模块;
逻辑执行单元,用于加载当前内容模块中的逻辑控制单元,并执行该逻辑控制单元中定义的逻辑内容;
判断单元,用于判断逻辑内容中是否包括加载其它内容模块的逻辑,若是,则将所述其它内容模块记为当前内容模块并执行逻辑执行单元,否则执行处理结果单元;
处理结果单元,用于生成结果视图数据,结果视图数据用于填充至根视图模块中。
4.根据权利要求3所述的基于WebApp的数据处理系统,其特征在于,逻辑内容包括:定义当前内容模块中的视图单元与事件单元中定义的事件的绑定关系;
和/或调用当前内容模块中的数据层单元从数据库中获取对应的数据;
和/或调用其它内容模块中的数据层单元从数据库中获取对应的数据;
和/或将获取的数据发送至其它内容模块中;
和/或将获取的数据结合当前内容模块中的显示模板单元生成当前模板格式数据,并将当前模板格式数据填充至当前内容模块的视图单元中。
CN201510779221.8A 2015-11-12 2015-11-12 一种基于WebApp的数据处理方法和系统 Active CN105320776B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510779221.8A CN105320776B (zh) 2015-11-12 2015-11-12 一种基于WebApp的数据处理方法和系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510779221.8A CN105320776B (zh) 2015-11-12 2015-11-12 一种基于WebApp的数据处理方法和系统

Publications (2)

Publication Number Publication Date
CN105320776A CN105320776A (zh) 2016-02-10
CN105320776B true CN105320776B (zh) 2019-02-05

Family

ID=55248162

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510779221.8A Active CN105320776B (zh) 2015-11-12 2015-11-12 一种基于WebApp的数据处理方法和系统

Country Status (1)

Country Link
CN (1) CN105320776B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108845839B (zh) * 2018-05-31 2023-07-14 康键信息技术(深圳)有限公司 应用页面加载方法、装置及计算机可读存储介质

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102656557A (zh) * 2009-10-14 2012-09-05 韦尔迈格服务有限公司 自动化企业软件开发
CN104113787A (zh) * 2014-05-29 2014-10-22 腾讯科技(深圳)有限公司 基于节目的评论方法、终端、服务器和系统

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2001093106A2 (en) * 2000-05-26 2001-12-06 Infolibria, Inc. High performance efficient subsystem for data object storage

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102656557A (zh) * 2009-10-14 2012-09-05 韦尔迈格服务有限公司 自动化企业软件开发
CN104113787A (zh) * 2014-05-29 2014-10-22 腾讯科技(深圳)有限公司 基于节目的评论方法、终端、服务器和系统

Also Published As

Publication number Publication date
CN105320776A (zh) 2016-02-10

Similar Documents

Publication Publication Date Title
CN103713889B (zh) 一种应用的开发、编译和调试方法以及装置
CN104851052B (zh) 一种用于输出调度操作票的智能防误方法及系统
CN103595770B (zh) Sdk实现文件下载的方法与装置
CN103618699B (zh) 一种调用组件的方法及装置
CN104410667A (zh) 一种xml报文到json报文的转换方法及系统
CN103345394A (zh) 一种快速制作原生手机应用软件的方法
CN104866327A (zh) 一种php开发方法及框架
CN104360937A (zh) 一种智能参数校验装置
CN104636400A (zh) 浏览器网页生成方法、浏览器及系统
CN109189400A (zh) 程序发布方法及装置、存储介质、处理器
CN104935639A (zh) 一种智能终端及其应用的分布式开发系统及方法
CN105320776B (zh) 一种基于WebApp的数据处理方法和系统
CN104050218A (zh) 用于提供要显示在用户界面中的信息的方法和系统
CN110109684B (zh) 区块链节点管理代理服务安装方法、电子装置及存储介质
CN106681704A (zh) 用户界面的开发装置和开发方法
CN103246503A (zh) 一种企业管理软件的应用开发架构
CN102752332B (zh) 一种业务激活方法和装置
CN103634385A (zh) 一种数据同步系统、方法及服务器
CN103294463A (zh) 一种编辑系统及方法
CN108804120A (zh) 一种页面构建方法、装置、设备及存储介质
CN102810065B (zh) 用于加载程序模块的方法和系统
CN106294119A (zh) 测试调度系统、方法及终端设备
KR20140111363A (ko) 좌표계 일괄 자동 변환 방법 및 이를 위한 장치
CN103916428A (zh) 私有云内部的数据传输方法、私有云平台及私有云系统
CN105897767A (zh) 调度方法、调度响应方法及设备和系统

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
CB02 Change of applicant information
CB02 Change of applicant information

Address after: 510032 15D room 159, Whampoa Avenue, Tianhe District, Guangdong, Guangzhou 01

Applicant after: Guangzhou Youshi technology Touchplus information Corp

Address before: 510000 Guangdong city of Guangzhou province Tianhe District Whampoa Road West No. 638, decimating Science (Guangdong agricultural letter) 603

Applicant before: Guangzhou Youshi Information System Co., Ltd.

GR01 Patent grant
GR01 Patent grant
CP03 Change of name, title or address
CP03 Change of name, title or address

Address after: Room 603, No. 638, West Huangpu Avenue, Tianhe District, Guangzhou City, Guangdong Province

Patentee after: Guangdong Youzhi Technology Co., Ltd

Address before: 510032 15D room 159, Whampoa Avenue, Tianhe District, Guangdong, Guangzhou 01

Patentee before: Guangzhou Youshi technology Touchplus information Corp.