Review in Seam

本文针对Seam框架在项目中的应用提出几点思考:1. 是否有必要使用EJB而非JavaBean;2. 应尽量使用Seam UI组件替代JSF组件;3. Conversation模式的合理运用;4. 开发过程中热部署、调试、自动生成代码的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近用休息之余看了《seam in action》和一些项目相关资料,总感觉我们的项目除了在代码质量上的问题外,还存在很多对于框架理解性的偏差,所以在很多细节的处理上都显得十分的盲目。我总结了下面的几个方面,与其说是我对项目现状的质疑,不如说我对于Seam和项目存在的一些疑问。

第一.项目是否有必要使用EJB

1.JavaBean是可以handle现有项目中所有的逻辑的,项目规模小不存在分布式的需求,引入EJB,相当于引入额外的复杂性;

2.Ear的项目打包格式,不提供EJB组件和JavaBean的热部署,让程序员的调试开发效率大打折扣;

3.Hibernate可以替代Entity bean,同样可以搭配JPA共同使用。

第二、项目应该尽量使用Seam的组件(尤其是UI组件),代替JSF组件。

1.相对于JSF组件,Seam的UI组件并不是简单对JSF在语法格式上的优化,Seam对JSF的改进是体现在处理Request的风格上,应该说是从本质上在改变JSF中“一切皆post”的处理风格。可以说,在Seam的项目中尽量使用SeamUI组件,是对Seam处理Request风格的一种肯定,而Seam的这种风格与Seam提倡的Conversation等等的特性是一脉传承的,所以说只有只有完全使用好Seam UI组件,才能有内及外的写出纯正的Seam应用;

2.貌似应该避免<h:commandButton>与commandLink,取而代之的是<S:link>和<s:button>,理由就是避免JSF中的submit form 方式的request;

3.<DataModel>和<DataModelSelected>标签取代<f:Datatable>(标签的具体拼写我记不清了),Seam的datamodel提供了action中数据集的注出,以及数据集中被选择的行数据向Action中的注入,从而省略了JSF中datatable与backbean的绑定操作。

4.<s:decorator>和richface,a4j等标签的标准化使用,这是强调页面是否为Seamful的,使用时最关键的保证页面标签使用的统一性与规范性。这才便于提高团队开发中代码的可读性。

第三、Conversation的用法,Conversation的使用归根结底在于Seam中对于组件状态的管理。

1.记得文档中提倡,不要将Entity bean作为组件维护在各个作用域中,取而代之的方式是,将Entity bean作为某个Action的属性,由Action将其注出到某个作用域,或者干脆就和此Action的作用域保持同步;

2.明确每个Action的分工,不要将两件不相关的事(由同时需要状态)放在一个Action中去处理,这样这个Action就会维护过多的状态;

3.Conversation的begin和end,是可以放在*.page.xml,然后通过页面流去维护的,这也是文档中比较强调(推荐?)的一种方式;

4.状态作用域的正确使用,是可以避免boring的用隐藏域进行页面之间的传参的;

5.JBPM is necessary;

6.理解并正确使用start、join、end的用法

第四、开发中重中之重的问题

1.热部署

2.debug

3.Seam中代码的自动生成,而不是copy、paste

4.Testng下的单元以及集成测试。

以上,就是最近反思的一些感想,希望在以下的时间里能够更深入的总结下Seam的东西。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值