积累

来源:互联网 发布:c#旅游系统源码 编辑:程序博客网 时间:2024/06/02 17:28
1-在tomcat启动时加入系统参数:
           -Dorg.apache.tapestry.disable-caching=true  
           -Dorg.apache.tapestry.enable-reset-service=true
           如果在eclipse WTP中启动tomcat,就加在服务运行的VM arguments中。

2-
Tomcat HotSwap配置:
    没有什么特殊的,编辑tomcat的配置,在Modules子页中去掉项目的Auto Reload选项,
    打开Overview子页Server区域中的Enable Tomcat debug mode,
    这样,更新了class文件后,就不用重新启动服务器或者重新加载context了。配合(1、)可以出现即时    修改即时观看结果的效果了,很方 便D。

3-
Tapestry4.0的一些默认编码是iso-8859-1的,一般我们要用UTF-8的,这样修改就行了。
    在${yourServletName}.application文件中加入如下配置:
        <meta key="org.apache.tapestry.messages-encoding" value="UTF-8" />
        <meta key="org.apache.tapestry.output-encoding" value="UTF-8" />
        <meta key="org.apache.tapestry.template-encoding" value="UTF-8" />

4-
一个页面对应一个class文件,这个class文件是BasePage的抽象子类,Tapestry中的特殊怪异用法,因为框架会自己生成实现类来管理变量寿命周期,因此,如果要声明页面参数(就是原来request中的传来的参数),一定要按照下面方式:
        @Persist
        public abstract String getName();
        public abstract void setName(String name);
        其中@Persist意思是把这个参数保存在session中以备后用
        注意:万万不可自己随便去做个完整的java property getter and setter出来,不然会遇到严重的多线程问题,切忌切忌切忌!

5-
页面转向和导航
        先说服务器内部转向。很简单,两种方式搞定:
        a)不用参数:在page类的Linstener的方法中返回页面名字,String
        b)带参数:在page类中注入目标页面:
        @InjectPage("FirstPage")
        public abstract FirstPage getFirstPage();
        ....
        public IPage doClick(){
              FirstPage page = getFirstPage();
              page.setMyGF("Rain");
              return page;
        }
        如果需要配合工作流引擎决定页面转向,就需要使用Tapestry API获得IPage实例:      FirstPage page = (FirstPage) this.getRequestCycle().getPage(
    "FirstPage");
              page.setMyGF("Rain");
              return page;
      
        该说客户端重定向了
       
也分成两种:
         a)无参数:
        @InjectObject("engine-service:page")
        public abstract IEngineService getPageService();
        ...
        public ILink doClick(){
              FirstPage page = (FirstPage) getPageService().getLink(false,"FirstPage");
              //page.setMyGF("Rain");//FirstPage的myGF参数除非指明了“@Persist”,否则设置参数将无效!
              return page;
        }

      
b)有参数:
        @InjectObject("engine-service:external")
        public abstract IEngineService getExternalService();
        ...
        public ILink doClick(){ 
             IEngineService service =  getExternalService();
             ExternalServiceParameter parameter = new ExternalServiceParameter("UserRegister", new Object[] { "param","abc"});
             ILink page = service.getLink(false, parameter);
             return page;
        }
         同时,要注意的是,该页面必须implement IExternalPage,并实现接受参数的方法public void activateExternalPage(Object[] parameters, IRequestCycle cycle)!
 
 
         如果要跳转到系统外部的地址去的话,直接throw new RedirectException("http://spaces.msn.com/teedywang/");就行了,tapestry特有的怪异的重定向,寒一个给他,当然,也可以调用this.getRequestCycle().sendRedirect("http://spaces.msn.com/teedywang/");

6-initialize()这个方法,的确,在页面表现的时候,执行两次。页面表现之前,初始化你的页面,然后页面表现你的业务逻辑,比如你要显示什么新闻呀等等。。。最后,页面在结束表现之前,再次执行这个方法,将你的properties 还原为初始值,这样,在你的下次再访问该页面的时候,不会因为 properties的值已经改变而造成意想不到的错误。

7-initialize()
detach()
attach()
pageBeginRender()
pageAfterRender()
它们的执行是有先后顺序的,其中只有initialize()方法会执行两次,其它的都执行一次。这些特点,足够你利用来做很多事。
页面在表现(render)的时候,我只以direct service举例:
1)执行initialize(),初始化该页面的properties,这些properties都应该是客户端的瞬时状态。
2)执行attach(IEngine value),获取你的engine。所以,你可以利用这个方法往你的web容器里面加载服务。
3)执行pageBeginRender(),同样是用来在页面表现之前,给你希望的变量赋值。。比如说,我基本上是用这个方法来获取Visit对象中储存的session值。
4)页面表现业务逻辑。你的什么Foreach啊,等等,现在才开始执行。
5)执行pageEndRender()。在你的页面业务逻辑表现完之后,如果你希望有什么后续工作,可以在这里执行。
6)执行detach()的super(),也就是执行AbstractPage里面Tapestry自己的detach(),目的是为了清空该页面所调用的 engine,visit,requestCycle。因为如果不清空的话,比如什么用户信息的话,就可能会泄露。这个方法的存在是 Tapestry基于安全性的考虑。
7)执行initialize(),再次将你的properties恢复为初始值。
8)执行detach()里面,你自己写的内容。。
以上仅仅最简单的情况下,这5种方法的执行顺序。。。

8-可以在Javascript里面使用Tapestry标签
   var data = "<span jwcid="@Insert" raw="true" value="ognl:current.name " />";
  注意: 标签要使用""引住,不加raw="true" 的话,是出现#&34;的html转义符号

9-在开发自定义组件的时候组件内的中文要使用_zh_CN.properties文件转为unicode码,不然在Jboss中会出现乱码。

10-
Form组件基本用法:
对于Form组件,也许现在阐述的内容让你一头雾水,不过看后面几种组件的介绍,就会逐渐明白的。
<form jwcid="leaveWord@Form" delegate="ognl:beans.delegate">
表单提交必须使用DirectLink方式。在这里,监听(listener)方法可以有两种使用方式。

第一种方式,将监听方法放在Form组件中声明,那么格式就是:
<form jwcid="leaveWord@Form" delegate="ognl:beans.delegate" listener="ognl:listeners.leaveWord">
这种方式的话,也就是说,凡是Form组件所包围的范围内,只要submitted,那么就会触发监听方法。

第二种方式,将监听方法放在Submit或者ImageSubmit组件中:
<span jwcid="@ImageSubmit" image="ognl:assets.submitImage" listener="ognl:listeners.leaveWord">
<img src="images/button/tj.gif" width="50" height="18" border="0"/></span>
也就是我们现在使用的方式,
这种方式的优点在于,如果Form中有多个submit按钮,我们希望不同的按钮实现不同的功能,那么这种方式就方便多了。

delegate="ognl:beans.delegate"这个参数用来连接Form和验证代理。在Form中的每一个FieldLabel和ValidField组件必须使用用一个验证代理。在MessageBoard.page文件中:
<bean name="delegate" class="com.cdmcs.tapestry.page.RegisterDelegate"/>
OGNL表达式beans.delegate解释一个验证代理。所有这个Form中的组件都将共享这个代理。


原创粉丝点击