首先单纯使用JSP来开发项目需要考虑的东西太多,开发效率不高。 既然有更圆的免费轮子,干嘛不用?
JSF的开发理念是组件开发,但组件开发没有一个好用的IDE开发工具怎么行,OperaMasks Studio目前觉得还不是非常的好用,我用OperaMasks框架做了一个简单的页面(也就是使用了它的TabLayout布局而已,外加一点文字),居然需要下载差不多800kb大小的文件,而且开发的过程中非常的小心,千万不要出差错,如果对JSF原理不是很熟悉的话,挑错的过程很痛苦。很难对JSF组件进行个性化。虽然说JSF的Sun定义的JEE标准,但有时"标准"这东西不是灵丹妙药,比如中国有这么多的股市专家,在网络、电视上指点股市,然而还是有很多听信了专家的话的股民也没有赚到多少钱。
Structs 的架构设计的比较简单,使用基于控制器导航和页面导航,也很容易扩展,而且与FreeMarker结合可以很容易的自定义标签库,非常的方便,不过Structs 1.X配置的步骤太繁琐了,需要定义对HTTP请求和响应的映射和所有的ActionForm对象等。Structs 2.X好像有所改观,但是目前为止Structs 2.x的参考文档好像不多,应用也不广.
Spring MVC的架构设计的非常优秀,可以和其他框架比如JSP、JSTl、FreeMarker、Tiles方便的进行集成,提供了强大的依赖注入功能,不过要想使用它需要先配置一大堆的XML文件,这我可不喜欢,而且对AJAX支持不够,这让它损失了很多用户。
GWT全名叫Google Web Toolkit,从名字上可以看出它目前定位为工具集,不是框架,单纯使用GWT开发Web应用程序好像不是很顺手。
Lift是基于Scala的一种Web开发框架,它的假想竞争对手是基于Groovy的Grails,不过目前来说还不是很成熟,知名度也不高,不过参考Scala的发展趋势,Lift应该很有发展的潜力,值得关注。
其实我觉得Eclipse RAP 框架非常的不错,是基于Qooxdoo的AJAX框架,从架构到实现,都非常的优秀,支持OSGI,和插件管理,可以像开发RCP一样开发Web程序,从RCP迁移到RAP也不需要费很大周折,不过目前RAP面对的一个问题是系统的运行速度(如果摩尔定律仍然有效并且也能用于网络宽带的发展速度上的话,那么RAP绝对是一门值得投资的技术)。国外也有公司已经开发出了RAP的商业产品,我试用了下,非常的惊艳非常的棒.
现在轮到Wicket了,Wicket 是 Sun公司的Swing UI小组开发出的一种构建和测试动态 Web 页面的简化框架,是一种开源、轻量、基于组件的框架,只使用Java和HTML代码,构建在Servlet API 之上,Wicket通过基于HTML的模板来界定HTML 页面设计人员和 Java 开发人员之间的角色界线.模板可使用任何的HTML设计工具生成.,也就是说Wicket可以让你有更多的精力放在应用程序的业务逻辑的实现上.如果你有SWT/Swing的开发经验,对其他的Web框架知道的比较少又像向Web开发这方面发展的话,那么Wicket一定非常的适合你。而且Wicket的性能还不错.提到Wicket就不得不提一下 Tapestry,这两个框架很多地方相似,你可以在网上看到Tapestry PK Wicket 的帖子,不过有人说"Wicket是重构后的Tapestry".现在你知道该选谁了吧.当然Wicket也有缺点,要掌握Wicket需要了解Java,有面向对象编程思想的话掌握Wicket很容易
好了,我已经决定了,要开始研究Wicket了,嗯,还是研究一下它的源代码先.
欢迎大家一起讨论,说出你心中最理想的Web 框架