关于webwor中注册例子的备忘(freemarker的基本使用)

阅读更多
以下是以一个注册的例子的实现来备忘关于webwork中view层的使用,主要是基于freemarker技术的。

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")}
这样就指向了/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"/>
	

在form中增加一个<@ww.token />,页面生成的时候会在form中自动增加一个隐藏域
xml文件中的设置:

			
			
			reg.ftl
		
		
			success.ftl
			repeatsub.ftl
			input
			
			
		

用户输入界面的action要添加拦截器
提交的action中要添加
同时还可以定义token不合法,系统自动跳转的页面repeatsub.ftl

你可能感兴趣的:(freemarker,CSS,XML,Webwork,工作)