快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

struts设计上的一点想法


一年多以前就开始学Struts了,但是一直没有机会使用它开发项目。在做了一些小的DEMO后感觉很好。但是最近的一个公司中使用了Hibernate+Struts的框架开发。我去的加入的时候,基本的框架已经建好了。我看后感觉开发框架很不规范,很多页面中都出现了脚本。在不少的地方都是利用HQL从查询数据库。他们为什么会这样做了呢?感觉很希奇,后来经理告诉我由于项目比较小,所以有些地方比较灵活了一点。

由于我们是按照功能模块分工(我很不习惯这种方法)。所以我可以按照自己的方法来开发,在开发中使用Form来封装了所有页面需要显示的数据。基本上就是按照MVC2的来开发。在Action使用DAO调用Hibernate操作数据库。将PO直接封装到ActionForm中,将页面上需要显示的数据都在Action中读出来放到ActionForm中去。在表单处理的时候将ActionFormCopy到对应的PO中,再传到DAO中操作。但是后来由于页面的改动。发现在ActionForm中封装的信息不够用了.这样常常修改ActionForm造成开发的速度很慢。每一次修改了都需要重新编译、发布、虽然IDE中操作其来道是很方便,但是还是感觉挺浪费时间的。假如修改了数据库的字段要修改PO和ActionForm,太麻烦了。后来想把ActionForm和PO和在一起。假如那样的话就得让PO继续ActionForm,这样就把一些验证的逻辑都混在一起了,,感觉不是很好的。而且这样会和前面的开发有很大的不同。

我想假如ActionForm不需要继续统一的ActionForm也许更好些,或者把ActionForm改成interface,如:  <form-beans>    <form-bean name="tinvListForm" type="com.cms.jxdc.model.TinvListForm" />  </form-beans>  假如”com.cms.jxdc.model.TinvListForm“没有实现ActionForm接口就把他作为一个简朴的VO看待了,在Hibernate中作为PO操作。这样就可以避免重复的些一些基本一样的Bean了。 也许这样在大项目中是很不严格的设计,但是对于象我目前的这种小的项目,在开发周期和人力资源都很紧张的情况下也是未尝不可的。

  在项目中还用到了Struts的tiles,感觉忽然一下就会增加好的也面啊。在使用的时候还是挺麻烦的,觉得有些也面是没有必要正加的。比如:  在一个list.jsp页面中:  <title:insert page="/layouts/main.jsp" > <title:put name="body" name="listbody.jsp" />  </title:insert>

  -----listbody.jsp-----<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %><table>  <tr>    <td >id</td>    <td >name</td>  </tr>  <tr>     <td>1</td>     <td>tet</td>  </tr> </table>我想这个listbody.jsp就是一个多余的页面,而且这样样开发、很不直观。假如在main.jsp需要很多小的tile组成,那样jsp文件数还会快速的增加。到后来徐徐就难以维护起来。list.jsp页面到是可以使用tile-defs.xml配置代替。不过这样就有多了一个配置文件。虽然配置可以增家一定的灵活性。但是由于配置文件的真确行很不好调试,过的配置文件、选项反而增加了开发的难度。假如可以按照如下的方法开发那就可以解决上面的问题了:<title:insert page="/layouts/main.jsp" >   <title:put name="body">     <table>   <tr>     <td >id</td>     <td >name</td>   </tr>   <tr>      <td>1</td>      <td>tet</td>   </tr>  </table>   </tile:put></title:insert>这样也一目了然在main.jsp中的什么地方,插入了什么样的模块。而且可以简化页面数据的传输。这样一个新的问题就是重用吧。以前的listbody.jsp不能重用了。不过我认为用tiles的主要目的是组装页面,简化布局修改带来的麻烦。可能是我还没有碰到tile重用的问题吧。不论怎样假如tile可以按照上面的方法使用的话。可以简化很多我目前的工作。所以我也有修改一下tiles标签的想法。呵呵,假如经理同意的话那就ok了啊。






返回类别: 教程
上一教程: 使用Hibernate 连接SQL Server 2000
下一教程: TIJ swot_JAVA的初学者(四)

您可以阅读与"struts设计上的一点想法"相关的教程:
· java函数传值的一点心得
· 面向对象的设计与实现的一些基础但重要的概念
· 使用validwhen设计复杂的Struts表单验证
· 关于java中字符编码的一点心得,可能对初学者有点帮助
· struts和hibernate整合的一种方法(hibernate作为struts插件)
    微笑服务 优质保证 索取样品