Q:是否应该使用tag。
A:一直比较困惑,其实个人不太主张使用tag,应为会把页面的展现和tag绑定的比较紧,对于css的调整,页面的布局来讲,不懂tag的人是很难上手的。目前的项目其实完全可以做到页面和代码逻辑分离,这样,js+css的人可以重点吧精力放在实现页面上,而逻辑部分由程序员实现。但是通过使用的不断增多,感觉tag在某些方面上还是很有优势的,程序员可以用tag做快速的界面开发,先把逻辑和流程走通,搭起一个原型来(当然这里的原型已经比较接近最后的成品了),然后再和view层的js+css结合,完成整个工作,这样两遍不受制约,而且改动也会比较少!
Q:如何使用namespace
A:namespace这个东西还是不错的,可以将不同的功能模块很清晰的分开,这样就不会造成诸如:action的重名、模板定位等问题,具体的做法如下:
在xwork.xml中include功能模块的xwork-xx.xml
这里需要注意的是,如果你需要模块中的action使用在xwork.xml中定义的拦截器、result type等,你就要将上面这行放到定义的后面去,因为xml文件是顺序解析的。
xwork-register.xml如下:]
reg.ftl success.ftl repeatsub.ftl input
Q:在超链接中如何使用namespace
A:可以定义一个url标签,然后通过a来使用url标签
<@ww.url id="intoself" namespace="/user" action="index"/> <@ww.a href="${intoself}" >${action.getText("reg.success.redirect")}@ww.a>这样就指向了/user/index.do
Q:使用namespace后,result中的ftl放置在哪里?
A:例如 namespace=/user,那么result中的index.ftl应该定位在${webroot}/user/index.ftl
Q:如何建立一个带token的form放置重复提交
A:以ftl模板为例:
<@ww.form action="save"> <@ww.token /> <@ww.textfield name="registerModel.email" label="${action.getText('reg.title')}" tooltip="${action.getText('reg.title.note')}" required="true" requiredposition="true"/> @ww.form>
在form中增加一个<@ww.token />,页面生成的时候会在form中自动增加一个隐藏域
xml文件中的设置:
reg.ftl success.ftl repeatsub.ftl input
用户输入界面的action要添加拦截器
提交的action中要添加
同时还可以定义token不合法,系统自动跳转的页面