`
liangguanhui
  • 浏览: 112892 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

NetBeans+VisualWebPack到目前为止发现的问题

阅读更多
(可能还有人不知道VisualWebPack是什么,VisualWebPack其实是sun java studio creator2netbeans的免费插件<http://www.netbeans.org/kb/55/vwp-index_zh_CN.html>,主要用于JSF开发,其拖拉式组件开发是其一个主要卖点。)


首先需要先说说JSF

1、尽管JSF是标准,但不见得标准就是好的。君不见EJB2的状况?像JSF这个复杂(指的是实现的复杂)的一个框架(相对于jsp、struts等),我怀疑它是否是另外一个ejb。而且虽然说JSF是标准,但每个厂商自己的实现多多少少都会有一些扩展(通常是组件的扩展),一个JSF程序一般很难在不同厂商的JSF实现中切换。

2、JSF的生命周期相对jsp来说比较复杂,虽然VisualWebPack已经简化了,但还是复杂,有很多时候我想取一个值(大多数情况是动态值),但是没有取到,我怀疑有一些bug(当然不排除我自己技术没到家),记得之前的项目大部分时间就是耗在这个取值的问题上。

3、JSF的组件设计如果不是使用IDE的拖拉式开发,工作量反而比直接使用JSP、Struts要多。IDE在JSF开发中显得尤为重要。

4、JSF的错误提示太多无用的信息,不能对错误迅速定位。

5、在ajax大行其道的今天,JSF这种把一切都包揽在server端的做法,我还真是有所保留!虽然有Ajax4JSF项目,但这个项目好像不是标准来的。

6、相对与ASP.NET和Tapestry,JSF对HTML的侵入性比较大,令Dreamver这些优秀的网页设计工具无用武之地。



现在来说说NetBeans+VisualWebPack

1、项目、资料、社区的支持度:现在使用JSF开发的项目还比较少,用NetBeans+VisualWebPack的就更少了。同时,由于VisualWebPack的出现比较晚,相关资料实在太少了,就算它的前身sun Java Studio Creator2的资料也是很少。缺少成熟的、稳定的、可持续的资料、社区的支持,如果出了问题,还真不知如何解决呢。

2、团体合作:(1)与美工比较难配合。我们很难说服一个用惯Dreamvwear的美工转用这个VisualWebPack。其实也是不可能的,你没有理由要求一个美工去学习JSF、VisualWebPack的标签,可能有人会认为,即使只是使用VisualWebPack的拖拉式也一样可以做出漂亮的界面。不过正如没有一个美工不懂HTML的道理一样,不懂JSF标签的美工,做界面总会有点美中不足。(2)由于NetBeans+VisualWebPack对某些文件极为敏感,很多时候,把一个工程打包到另外一个机器的时候,往往不能打开;有时候还要解决包引用的问题(NetBeans说这个是它的优点,但我反而觉得是一个不足);更加不用说使用cvs版本控制了。到目前为止,VisualWebPack给我的感觉就是很难做大项目。

3、IDE的问题:不得不说,VisualWebPack还有很多bug,功能比较弱,组件偏少,而且耗资源很大,速度慢得有点受不了;跟Visual Studio相比,感觉还是有相当的差距。JSF本来对IDE的依赖就比较大,VisualWebPack的不足无疑是雪上加霜!

4、组件性开发:VisualWebPack的拖拉式组件开发从表面上看好像是很方便,不过用起来却是诸多不足,如果某一个功能可以有现成的组件实现,那倒很方便,如果没有,那是一件很痛苦的事情(同时由于VisualWebPack组件相对不足,令这种痛苦更加升级)。桌面程序不同于web程序,一般人对他们都不会有额外的美工要求,基本就是堆上组件就可以了。而web就不同,情况要复杂得多,经常有千奇百怪的要求,这种要求,通常用javascript实现可能比较容易,但由于VisualWebPack偏重于server端以及生命周期的限制,注定它跟客户端的javascript比较难结合,换言之,web的特殊效果也就很难实现。比较常见的是菜单、IFrame等。

5、与旧有项目结合:我们以前已经习惯了spring+hibernate做底层,现在发现VisualWebPack跟他们集成在一起好像问题比较大(或者说,处理系统分层比较麻烦)。例如,VisualWebPack的表格组件,对数据库的操作都推荐使用那个DataProvider。到目前为止,我们还没有找到集成的方法(还望高人指导)。另外,VisualWebPack里处理数据库的DataProvider用得最多得是CachedDataProvider,这个东西也真够古怪的,sun默认的例子是把数据缓存到Session里面。我真搞不懂,为什么sun那么喜欢把数据缓存到Session里面。

6、历史的倒退:(1)JSF有值绑定和控件绑定两种绑定方法(不知是不是这样叫),VisualWebPack默认是控件绑定的,在取得用户输入值得时候,我发现这是一个倒退,因为我还是需要一个一个控件调用getText(),这种操作我觉得跟request.getParameter倒是没有什么区别(可能就是增加了验证和类型转换吧)。(2)JSF刚出来的时候就嘲笑Struts的action必须要继承Action,因为JSF的managed bean是一个普通的java类(POJO)。但VisualWebPack现在的managed bean却走回struts的旧路,需要集成AbstrackPageBean。

7、风险成本:无论是从人员贮备、资源文档、厂商支持、安全稳定来说,相当多公司使用VisualWebPack基本都是亮红灯的。风险成本不容忽视!

8、其余问题:(1)VisualWebPack基本上是抛弃jsf的标准组件而使用自己的一套组件,这样多多少少会增加一些学习成本(不过这点也说不上是缺点)。(2)jsp文件对应的java文件,里面有一大堆的getter/setter,把源代码搞得很乱,同时,很难从IDE的“成员试图”中迅速定位。(3)NetBeans由于是使用Swing,字体显得比较丑。同时,字体边缘会有一些模糊。(4)有时候,修改了jsp文件或者java文件后,可视化设计就不能使用,由于提示不足,很难知道错在哪里,有时甚至需要重建页面。


谈就谈到这里,希望高手们都来说说自己的观点,并指出我的不足,谢谢

  • 大小: 104.7 KB
分享到:
评论
11 楼 milifan 2007-09-19  
不知道该怎么说,每种技术都有每种技术的优点和缺点吧!
最近在学习VWP,金蝶的OperaMasks也看过一段时间,在比较一下的话,还是觉得VWP好些吧!
10 楼 liangguanhui 2007-03-15  
VisualWebPack就是JSF的一个可视化工具,可惜做得不是太好
9 楼 nicemike 2007-03-15  
sorry 还以为没发成功~~~发了两次。。。。
8 楼 nicemike 2007-03-15  
觉得jsf不会起多大浪,用过几次,慢的要死~~~,就这点就对它的前途是个巨大的打击!!!不过从nb网站下到一些老外的演示flash,只有一个感觉:老外的机器配置太高了!!!googlemap都不带停的何况jsf!!~~~所以个人感觉jsf国内来说基本没有什么用武之地~

还有就是复杂,学习的时间较长~~~
如果不能用dw来编辑它生成的页面,那几乎就没有多大的用武之地了~~~毕竟做web开发的dw是个必要的工具,不可能页面的样式了什么的还要去手工的编码!!!
7 楼 nicemike 2007-03-15  
觉得jsf不会起多大浪,用过几次,慢的要死~~~,就这点就对它的前途是个巨大的打击!!!不过从nb网站下到一些老外的演示flash,只有一个感觉:老外的机器配置太高了!!!googlemap都不带停的何况jsf!!~~~所以个人感觉jsf国内来说基本没有什么用武之地~

还有就是复杂,学习的时间较长~~~
如果不能用dw来编辑它生成的页面,那几乎就没有多大的用武之地了~~~毕竟做web开发的dw是个必要的工具,不可能页面的样式了什么的还要去手工的编码!!!
6 楼 ssuupv 2007-03-01  
JSF用用,还是不错的,要想用完JSF,必须学会自己写组件
5 楼 icefire 2007-02-28  
ASP.NET也很烦的,不过好处是有好的IDE和有MS这个官方!
JSF还没打算用,不过正如struts,就算被批斗得体无完肤,但是许多人用起来还不是一样很顺吗?
精通了,也就觉得不错了!
金蝶有个脸谱,可以看看!是通过验证的!
4 楼 liangguanhui 2007-02-28  
不知楼上是用什么IDE?
3 楼 jones 2007-02-27  
我们公司正在用JSF+SPRING+HIBERNATE开发一套工作流驱动的协同办公系统,虽然开始感觉JSF十分的别扭,可是项目进行三四个月后项目组成员基本上都能十分熟练的使用JSF,个人认为关键是对JSF底层的理解和各个生命周期阶段的深刻了解!
2 楼 liangguanhui 2007-02-27  
自己探索
1 楼 Allen 2007-02-27  
现如今连SUN自己在推动JSF的时候都不像以往那般卖力了,可见JSF的日子确实不是很好过啊……

另外,贵公司是新招揽会JSF的人加入团队,还是自己在摸索中掌握它呢?

相关推荐

    基于Matlab极化天线和目标之间的信号传输建模 matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    移动通信网络中集中式无线电接入网的数据处理需求与性能指标分析

    内容概要:本文提出了一种新的分析框架,用于评估集中式无线电接入网(RAN)的数据处理需求。作者定义了若干性能指标,如计算失效概率、复杂度、增益、多样性和复杂度率之间的权衡。该模型基于块瑞利衰落、距离相关路径损耗和部分功率控制假设下进行仿真验证,证明了集中计算资源的优势。 适用人群:通信工程领域的研究人员、5G技术开发人员和无线网络优化专家。 使用场景及目标:①理解集中式RAN架构对网络性能的影响;②评估集中化数据处理资源在提高吞吐量方面的效益;③量化集中式RAN系统的数据处理复杂度和可靠性。 其他说明:文章通过对多种场景和参数设置的仿真研究,展示了集中式RAN系统相对于传统分布式系统的优越性,为未来移动网络的设计提供了理论支持和技术依据。

    444.exe44444

    444.exe44444

    华为 ArkUI 框架的创新与生态探索.pdf

    华为 ArkUI 框架的创新与生态探索.pdf

    hufuman压缩算法,实现数据的压缩与解压缩

    哈夫曼解压缩算法实现

    GLake_ 高效透明的大模型显存管理和优化.pdf

    GLake_ 高效透明的大模型显存管理和优化.pdf

    美团 AdHoc 统一查询引擎实践.pdf

    美团 AdHoc 统一查询引擎实践.pdf

    C#基于MVC的.Net技术类门户网站源码数据库 SQL2012源码类型 WebForm

    基于MVC的.Net技术类门户网站源码 这是一款作者结合工作中积累的一些经验,开发的一套.Net门户类网站,界面十分 精美,功能也相当完善,想了解MVC的可以参考下。 该源码主要包括网站前台和管理后台两大部分,具体功能如下: 网站前台模块:主要包括了各类文章信息的检索、详细浏览、发表留言等功能。 网站后台模块 1、系统:后台首页、修改密码、菜单管理、操作记录、网站设置。 2、后台账号管理:管理员列表、部门管理、角色管理、权限管理。 3、资讯管理:添加文章资讯、所有文章列表、资讯分类管理、文章采集、新闻采集。 4、互动管理:留言管理。5、广告管理:广告列表、添加广告。6、相册管理:相册列表。 源码特色: 1、项目框架基于.Net多层架构+MVC,SQL2012,,需要安装MVC3.0。 2、使用了AutoMapper,和StructureMap,进行依赖注入。 3、归纳和整合了比较全的工具类,一并放入到了Gongap.Common类库中。

    huqehufhq1dwqe

    huqehufhq1dwqe

    Java基于springboot+vue的餐饮连锁店管理系统的设计与实现.rar

    【基于Springboot+Vue的设计与实现】高分通过项目,已获导师指导。 本项目是一套基于Springboot+Vue的管理系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。也可作为课程设计、期末大作业 包含:项目源码、数据库脚本、开发说明文档、部署视频、代码讲解视频、全套软件等,该项目可以直接作为毕设使用。 项目都经过严格调试,确保可以运行! 环境说明: 开发语言:Java 框架:springboot,mybatis JDK版本:JDK1.8 数据库:mysql 5.7数据库工具:Navicat11开发软件:eclipse/idea Maven包:Maven3.3

    计算机挑战赛2021程序设计赛C++

    计算机挑战赛2021程序设计赛C++

    java小区物业小程序源码数据库 MySQL源码类型 WebForm

    Java小区物业小程序源码 运行环境:jdk8+tomcat8+mysql5.7+IntelliJ IDEA+maven 使用技术:spring+spring mvc+mybatis+layui 项目描述 微信小程序物业管理系统,微信小程序端包括以下几个模块: 社区公告、报修、信息采集、生活缴费、二手置换 微信小程序后台管理界面可以增删改查社区公告、问卷、问卷问题、问题选项等 在微信小程序前端,用户提交信息后,可在我的界面查看提交的信息,管理员可 以在微信小程序后台管理界面查看所有用户提交的信息。

    地球物理学双差伴随层析成像方法研究与应用

    内容概要:本文介绍了一种基于伴随层析成像技术的‘双差法’(double-difference)方法,用于地震波速度结构反演。这种方法通过构建站间差异测量来减少源签名和系统误差的影响。文章详细探讨了‘双差法’在理论和实际应用中的实施步骤,包括差分时间的计算、不适定性问题的缓解、以及灵敏度比较等内容。数值实验表明,相比于传统的绝对测量,‘双差法’提供了更高分辨率的结构信息。 适合人群:地球物理学家、地震学家、研究人员、地质工程专业的学生和从业人员。 使用场景及目标:本方法适用于需要高精度地层结构解析的研究,如地震活动监测、资源勘探、地壳结构研究等场景。目标是在减少噪声干扰的同时提高成像精度。 其他说明:文中还讨论了聚类分析和正则化方法的应用,以增强问题的稳定性并降低计算成本。同时,‘双差法’对源信号函数错误较为鲁棒,在某些情况下可以更好地分离时相。

    03 曲柄摇杆机构的运动分析.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    06-3 外槽轮机构设计计算.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    体适能_2.0.8.apk

    体适能_2.0.8.apk

    (源码)基于TreasureHunt项目的户外寻宝游戏系统.zip

    # 基于TreasureHunt项目的户外寻宝游戏系统 ## 项目简介 TreasureHunt是一个旨在鼓励户外活动的寻宝游戏系统。该系统包括一个或多个宝藏和一个寻宝设备(猎手)。通过此项目,参与者可以在户外享受寻找宝藏的乐趣。 ## 项目的主要特性和功能 1. 宝藏与猎手交互猎手设备能够检测并追踪附近的宝藏。 2. 真实距离估算通过WiFi信号估算宝藏与猎手之间的距离。 3. 3D打印的抛物面反射器用于增强猎手设备的信号接收能力。 4. 丰富的用户界面提供详细的操作指南和指示,帮助用户更好地使用该系统。 5. 测试与实验项目中还包括对如何通过WiFi计算距离的尝试和文档记录。 6. 多重库支持项目使用了多个库,如Adafruit SSD1306、Adafruit GFX Library、Adafruit BusIO等,以实现各项功能。 ## 安装使用步骤

    基于Vue+Node.js+MySql小说网站

    基于Vue+Node.js+MySql的小说网站

    基于百度飞桨PaddleOCR的C++代码修改并封装的.NET的OCR工具本地类库,可离线使用 包含文本识别、文本检测、表格识别

    PaddleOCRSharp是一个基于百度飞桨PaddleOCR的C++代码修改并封装的.NET的OCR工具本地类库,可离线使用。包含文本识别、文本检测、表格识别功能。本项目针对小图识别不准的情况下做了优化,比飞桨原代码识别准确率有所提高。 包含总模型仅8.6M的超轻量级中文OCR,单模型支持中英文数字组合识别、竖排文本识别、长文本识别。同时支持多种文本检测。

    基于Springboot+Vue的江西红色旅游景点宣传网站(管理端代码)

    基于Springboot+Vue的江西红色旅游景点宣传网站(管理端代码)

Global site tag (gtag.js) - Google Analytics