一些很肤浅的东西,不过在你用struts做项目的时候很有可能碰到,而且好像还没见有什么书上提到过这些问题,有兴趣的可以看下...如果有什么不对的地方还请高手指出(我用的版本是1.1, 1.2没研究过)
1.如果你自己写form bean的话,字段属性不要用Date,最好用String代替.因为如果你用Date型,在网页表单中相应输入项又不输入数据的话,提交时程序就无法对你的form bean完成初始化.而且一点错误提示都没有,log中也不会打印错误堆栈,保证急死你.而且validator也同时不起作用,你自己写validate方法也一样.(很奇怪,如果你是刷新页面来提交表单的话有可以了...)
这个问题我曾在apache的bugzilla上提出过http://issues.apache.org/bugzilla/show_bug.cgi?id=34385
他们给我的回答是:
ActionForms used to hold HTML form input should be using String fields.
(不过这个说法被人骂了,在bug 22730里面:
It actually works quite well for Number types. And for the Date with the
default format.
I do not understand why it's so difficult for you to make one step forward
instead of 10 backwards saying that you do support any types but String.)
笑昏掉...
不用担心在写数据库的时候会出问题,因为Date型和String型写入形式都一样,如果你是用PreparedStatement的话,用setString()来对Date字段付值也可以.
2. 不要以为在Struts的jsp页里只能用Struts的<html:html>标签,普通的html标签同样可以用,而且在有的情况下Struts的标签非常的不好用,用普通的html却非常方便,要看情况选择.
总体来说,struts的标签最大好处在于他可以动态绑定某个form bean及其字段属性或其他东东,而普通的html标签不具备这个功能.比如说在page范围内有一个xxxFrom的bean,其中有个字段xxx的值为yyy,表单名为xxxFrom,那么如果你用<html:text property="xxx"/>的话,将会生成<input type="text" name="xxx" value="yyy"/>的输入框,但是如果你用普通html标签的话,value值将不会被显示(也可以定义一个变量等于xxxForm.getXxx(),在value中用<%= %>动态显示,但是比用struts标签麻烦多了)
这对表单验证很有帮助.比如说如果你输入的某些数据不符合你定义的严整规则,出错返回时,用struts标签的字段将自动添入你刚才已经输入过的数据,不用你再次输入,但是如果你用普通html标签的话将不具备这个功能.
但是这个特点也带来一些让人不舒服的东西.比如说如果你有个字段定义为int型,而int型的默认初值为0,不能为空,
那当你第一次访问该表单的时候,所有int型字段的输入框将被自动添上0,看起来很不舒服.
所以建议在int型字段输入框上加一个
<logic:equal value="0" name="xxxForm" property="xxx">
<input type="text" name="xxx"/>
</logic:equal>
<logic:notEqual value="0" name="xxxForm" property="xxx">
<html:text property="xxx"/>
</logic:notEqual>
这样看起来舒服多了.当然如果这个项本来就可以输入0的话,就不要用这个方法了.
struts框架还有一个不好的地方就是不支持嵌套使用,比如说<html:text property="<bean:write name="xxxForm" property="xxx"/>"/>之类的使用将抛出错误.如果你要把标签的某个属性用struts标签来定义,那就不得不使用<input type="text" name="<bean:write name="xxxForm" property="xxx"/>" />了,或者你也可以用<bean:define id="xxx" name="xxxxForm" property="xxx" />来定义一个变量然后再在属性里面用<%=xxx%>来显示.
3.如果你手动写form bean的话,建议extends ValidatorForm或者ValidatorActionForm,这样你装个Validator插件,只需要在validation.xml里面配置一下验证规则就可以实现对输入字段的验证了,省去了你写一大堆字段验证的代码的麻烦事,高效又快捷.爽得很...