到 Google 资讯主页   
EasyJF首页   资料   源码   软件    论坛   网站    
   使用帮助    
    该信息为本站MyRSS系统缓存内容,部分图片及附件有可能无法正常使用.easyjf.comBlogJava无关,不对该信息负责.通过http://kb.csdn.net/keyword/java//../../java/Articles/200603/c2407d6b-09f5-46c8-accc-e159613f7fa4.html访问该信息的原始内容.
页面功能  【加入收藏】 【推荐给朋友】 【字体:  】 【关闭】   
Webwork2.2.2 重返Client Validation
作者: 来源:BlogJava  发布时间:2006-03-30 00:00:00.0

        自Webwork2.2发布以后,Webwork的验证机制就全部改由Ajax验证。验证的原理是一个需要验证的表单域在onblur时发送一次请求到服务器端进行验证,然后实时提醒。虽然这样达到验证目的,但在我看来,这恶心死了。如果我有一个表单几十个域需要验证,我在各个域之间切换的话,我的服务器还不累得够呛?可怜原来有的客户端验证功能没了。。我只好手写Javascript了。。
       到了Webwork2.2.2这个版本,有个好消息来了。Webwork重新支持客户端验证。于是马上抢先试了试。

       客户端验证的例子可见Webwork自还的例子“showcase”。使用客户端验证大体上跟以前的服务器端验证相似,只是多了一些步骤。完整的有以下几个步骤:
       一、编写XXXAction-alias-validation.xml--验证配置文件。文件放在需要验证的Action类同一目录下,alias是可选项,如果有几个Action使用了同一个Action类。而你想对其中一个Action进行验证,那么alias就是那个Action的名字。如:PersonAction.java,被editPerson,savePerson,deletePerson等Action使用到,而仅需要对savePerson这个动作来验证时,配置文件名字就是:PersonAction-savePerson-validation.xml。Webwork支持的客户端验证类型有:

  • required validator
  • requiredstring validator
  • stringlength validator
  • regex validator
  • email validator
  • url validator
  • int validator
  • double validator

       二、配置Xwork.xml,保证拦截器栈里有Validation的拦截器
       三、编写Jsp(VM或FTL)。这里有几个需要注意的地方。
       1.在Jsp加上一个Head标签,<ww:head/>的结果是生成两个Css样式的链接:
<link rel="stylesheet" href="/bean/webwork/xhtml/styles.css" type="text/css"/>
<link rel="stylesheet" href="/bean/webwork/jscalendar/calendar-blue.css" type="text/css"/>
主要是获取显示错误是的样式。
       2、使用<ww:form>,很遗憾我们只能够用Webwork的UI标签,这样才能使用到她的客户端验证机制。在这里要抱怨一下。。<ww:form>的标签是挺方便,但是在特定的场合,我们必须使用自已的样式和风格的布局。而Webwork默认的XHTML主题的标签会把布局搞乱。当然,我可以使用Simple主题的。但是在需要客户端验证的时候,Simple主题是行不通的。也就是说要求主题必须是XHTML以上。。或者自定义的主题(自已提供错误信息报告功能)。呵。没办法,先将就着用XHTML吧。
       在<ww:form>的标签里使用namespace 及Action属性。如果你的Action是/foo/bar/new.action那么,你必须这样写:
       <ww:form namespace="/foo/bar" action="new"  validate="true"/>
validate="true"一句将会在客户端生成一句:
   <script src="/bean/webwork/xhtml/validation.js"></script>
如果你这样写:
       <ww:form action="/foo/bar/new.action" validate="true"/>,你将得不到客户端验证。要注意,这个细节不容忽视。我被这个小问题搞大头了。后来查文档的时候才知道Webwork已经提醒我们要像上一种写法那样写。因为她要知道哪个名字空间下的哪个Action需要被验证!看吧。这是心急的错。不看文档后果就自负。
       以上两种写法,在页面上生成Js的结果是不一样的。第一种写法会在页面上生成相应的验证规则。第二种写法生成的Js,只是简单清楚报错信息然后提交请求到服务器,由服务器来验证。

       只需要这三步,Webwork2.2.2的客户端验证功能就算是使用了。感觉还不错。唯一纳闷的还是Webwork强制我什么使用她的模板。
       Ps:有很多示例代码没同贴出来,是有原因D。现在编辑是使用FCKEditor,另外两个Editor在我的机子上变成了白痴。出错、完全不能编辑。。。手上又没有好的“XML到 HTML”的好工具。。所以没把代码贴上来。。详情,可以看Webwork的Showcase。这东西太出彩了。:P

艾尘 2006-03-30 16:47

 
相关文章
 
页面功能  【加入收藏】 【推荐给朋友】 【字体:  】 【关闭】   


EasyJF.com 2006 隐私政策 使用EasyJF前必读