升级JSF1.2的艰难之旅

开发 后端
本文介绍把JSF从1.1升级JSF1.2,这个过程中暴漏出JSF的一些不足。

最近由于项目的要求需要把JSF从1.1升级JSF1.2,这个过程中暴漏出JSF的一些不足,如下:

一,原来在1.1下运行很正常的backing bean 不再正常了,调试之后发现有些backing bean 竟然是使用的包级私有的构造函数,但是很纳闷怎么在1.1下正常而1.2下就实例化不了,可能是JSF 1.1 的实现中是利用反射机制进行backing bean的初始化吧,而1.2又改成调用backing bean 的默认构造函数了,所以碰到包级私有构造函数的backin bean 才出现无法实例化的异常吧。

二,JSF提供的组件中的那个SelectOneMenu个人认为有一个不足之处,如果服务器端初始化组件树时候有四个待选项,到了客户端页面通过 ajax对待选项进行了修改,比如改成了五个,这中情况下你页面中的所有command类型的组件的方法绑定都会失效,跟踪JSF源码发现这个 SelectOneMenu的Render中首先进行了一个个人认为画蛇添足的校验,它首先校验你提交上来的那个值是否在组件初始化时候提供的待选项内,如果不是待选项中的某个则直接生命周期最后阶段并忽略了中间的所有处理,包括你的方法绑定,这个问题很隐蔽,一般很难发现,这个校验个人认为为客户端使用 AJAX带来了很大的麻烦,动态修改下来菜单的选项是很普通的ajax应用了(比如多级联动下拉菜单),为了给SelectOneMenu提供ajax能力我不得不重新实现了一个SelectOneMenu,现在我把工程升级JSF1.2,才发现JSF1.2的核心api正如官方所言没有重大改动,只是统一了EL,但同时我确发现JSF的一些“不重要”的API改动确很大,我自己开发的组件用了1.1中的**util类,可是现在发现那些静态方法现在都没有了,这时不得不再次重新写一个SelectOneMenu,这回一点儿它的**util类也不用,免的下回升级JSF1.2还重写。

三,JSF 1.1 RI中的commandLink居然把dom中的onClick()自己占用了,发现JSF1.2 RI又还回来了,这点还是做的不错的,不过却发现JSF组件ID系统自动生成的算法改了,1.1中如果你没有给页面上的组件指定ID那么JSF会按照某种算法自动生成一个,可是1.2中不但为这个自动生成id的行为增加了一个“开关”,而且生成算法也改了,这回麻烦大了,当初项目组中很多成员比较懒,页面中的javascript直接就是用的那个自动生成的ID,这回生成算法一改页面中的大部分javascript都瘫痪了,唉,懒人啊!

四,原来1.1与Spring整合的时候发现Spring提供的JSF变量解析器只能整合MyFaces,不得不使用了jsf-spring.jar进行jsf RI+spring整合,现在突然发现JSF1.2 RI终于可以直接使用spring的变量解析器进行整合了,这点儿还是不错的。表扬一下!

五,原来项目中的上传下载使用了MyFaces的tomahawk组件包中的部分组件,可是到apache的网战上一看虽然MyFaces-core出了1.2版本,但是tomahawk还仍然停留在1.1,唉!组件版本不兼容的烦恼啊!

小毛病还有很多就不一一列举了,总体一句话,JSF还真是有待进一步发展啊!

【编辑推荐】

  1. 使JSF支持带有HTMLMessage
  2. JSF如何使用ExternalContext
  3. 在JSF应用中捕捉managed-bean构造方法
  4. OSGi与JSF结合开发
  5. 浅谈JSF的生命周期和对ajax处理的影响
责任编辑:佚名 来源: JavaEye
相关推荐

2009-06-25 11:21:36

JSF流行名词

2011-08-10 10:33:18

路由器Cisco

2009-06-10 16:11:28

JavaFX SDK升级

2009-06-25 11:11:25

控制JSF切入点

2009-06-23 14:25:41

JavaFX1.2

2016-06-14 03:59:00

WWDC苹果开发者大会

2009-09-23 17:56:45

JSF入门

2009-06-25 13:03:48

JSF的UI组件

2009-06-17 15:18:38

JSF与Spring

2009-06-23 13:21:26

JSF和Spring

2009-06-29 13:22:19

JSF技术JSF组件

2009-06-22 16:42:26

JSF的工作方式

2009-06-26 13:48:57

G4JSFGWTJSF

2009-06-26 14:06:08

JSF基础框架

2021-05-31 07:49:58

物联网OTA软件

2012-02-24 15:25:45

ibmdw

2009-06-11 11:28:35

JSF生命周期

2011-07-21 17:11:09

AjaxJSF

2009-06-22 15:35:31

JSF和Struts

2009-06-22 14:07:46

JSF优势
点赞
收藏

51CTO技术栈公众号