- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于Spring MVC和Mybatis动态表单设计
基于Spring MVC和Mybatis动态表单设计
摘要:由于用户对业务需求的不明确或者业务的变化,常常在开发甚至使用过程中要求增加数据库字段,在前台表现为需要变更表单。针对此种需求,提出基于Spring MVC和MyBatis,将字段设置为动态的,表单也动态生成,以满足用户业务变化的需求。
关键词:动态字段;动态表单;Spring MVC;MyBatis
中图分类号:TP393.09 文献标识码:A 文章编号:1007-9599 (2012) 20-0000-02
1 引言
在实际的项目中,用户常常在开发过程中,甚至上线后要求对表单和数据库增加或减少一些字段,减少比较容易处理,增加字段则较为麻烦。如果和用户业务有关的表字段能够动态的处理,表单也能够动态生成,那么用户自己就可以对业务进行维护,无需开发人员介入。此种方式具有更好的可用性、灵活性、交互性,并且所设计的系统也具备更强的可移植性。
2 Spring MVC、Spring和MyBatis介绍
Spring是一个开源框架,其核心是IOC(控制反转)和AOP(面向切面编程),提供了Java EE开发各层的解决方案,同时,也提供了对其它框架的整合,发展到今天,Spring几乎已经成为Java EE 的代名词。Spring MVC是Spring的一个用于构建Web应用的全功能MVC模块,在进入Spring MVC 3.0版本后,由于全注解方式的使用,相对于Strtus 2来说更为简单易用,响应速度在多个测试中也略胜一筹,并且和Spring天然集成。MyBatis是ibatis进入3.0版本后改名而来,是一个优秀的ORM框架,使用XML文件或者注解方式配置和原始映射,特点是提供了强大的动态SQL功能。相对于Hibernate而言,开发工作量会更大,也丧失了数据库的移植性,但提供了更大的灵活性和性能的可控性。
3 数据存储方式
图1是动态表单的数据表设计,其中,模板表存储的是表单的名称,表示是哪个数据表单。数据项表存储的是表单的数据项,数据项类型字段存储int类型,主要分为以下几项:
(1)取值1为文本:单文本数据项,在前台显示为文本框,此时参数1为长度,参数2为正则表达式规则。
(2)取值2为整数:在前台显示为文本框,此时参数1为最大值,参数2为最小值。
(3)取值3为小数:在前台显示为文本框,此时参数1为最大值,参数2为最小值。
(4)取值4为日期:在前台显示为日期选择框,此时参数1为输入格式,如“yyyy-MM-dd”,参数2为输出显示的格式,如“yyyy年MM月dd日”。
(5)取值5为多行文本:在前台显示为多行文本框,此时参数1为文本最大长度。
(6)取值6为列表:在前台显示为下拉选择框,此时参数1为列表值,用特定分隔符隔开,如“男,女”。
是否必填字段表示是否允许该字段为空,是否列表字段表示该字段在是否出现在分页查询列表中,是否检索字段表示该字段是否在分页查询页面作为查询条件出现。
数据项值表用于存储数据项的值,存储方式不再是传统的横表,而是竖表,每一条记录存储一条记录里一个字段的值,记录编号相当于是传统存储方式的主键,用于将多个值关联成一条传统意义上的记录。竖表的存储方式值字段均为字符串型,需要开发者编写代码将字符串类型转换为其它数据类型。在查询记录时,将竖表转换为横表显示的sql代码写在MyBatis的配置文件中,因为字段不固定,MyBatis不将动态表单查询到的内容映射为实体,而是映射为Map。
在系统中,必须先定义模板,再定义模板所包含的数据项,在定义数据项时,必须将数据项的名称、类型及对应的参数1和参数2定义好。删除数据项时,并不在数据库中真的删除,而是将状态置为0。
4 动态表单的生成
在spring mvc中,通过调用service层和dao层,查询到表单所需要的数据项,放入list中,跳转到jsp页面,使用jstl的、标签,根据数据项的类型值,显示不同的表单,关键代码如下所示:
${field.showname}:
在表单提交时,onsubmit事件中,添加javascript的表单验证方法,使用jquery根据input标签的class元素进行选择,为每种类型的数据项使用不同的表单验证。并通过input标签添加的allowedEmpty、parameter1、parameter2元素的值,来判断是否允许该表单为空,及最大、最小值,正则表单式等信息。
5 小结
本文描述了一种动态表单的设计,表单的数据项动态添加,表单根据数据库的字
文档评论(0)