首页 > 代码库 > Tapestry5.3 总结

Tapestry5.3 总结

文章摘自: http://blog.csdn.net/javaman_chen/article/details/9351237

不得不说,人家总结的真好。。。

 

 

1.Tapestry框架的加载是通过Filter来完成的,需要在web.xml中加入以下配置:

[html] view plaincopy
 
  1. <filter>  
  2.     <filter-name>app</filter-name>  
  3.     <filter-class>org.apache.tapestry5.TapestryFilter</filter-class>  
  4. </filter>  
  5. <filter-mapping>  
  6.     <filter-name>app</filter-name>  
  7.     <url-pattern>/*</url-pattern>  
  8. </filter-mapping>  

2.这里面,过滤器拦截了所有的URL,某些时候可能希望有一些URL不被拦截(比如Servlet的mapping-url)
这时候需要通过构建IgnoredPathsFilter服务,把不需要拦截的url添加到配置中去
在Module类中,添加以下方法:

[java] view plaincopy
 
  1. public static void contributeIgnoredPathsFilter(Configuration<String> configuration){  
  2.     configuration.add("/topic");//添加后/topic路径不被Tapestry过滤器拦截  
  3. }  

除了上述方式,还可以为应用程序单独指定一个context

[java] view plaincopy
 
  1. public void contributeApplicationDefaults(MappedConfiguration<String, String> configuration){  
  2.     configuration.add(SymbolConstants.APPLICATION_FOLDER, "myApp");  
  3. }  

同时修改filter的url

[html] view plaincopy
 
  1. <filter-mapping>  
  2.     <filter-name>app</filter-name>  
  3.     <url-pattern>/myApp/*</url-pattern>  
  4. </filter-mapping>  

这样,便不会影响其他Filter和Servlet的使用

3.Tapestry遵循"约定大于配置"的开发原则,以contribute为前缀的方法会自动被框架识别(比如上面的contributeIgnoredPathsFilter方法),除此之外还有其他一些约定:
以decorate开头的方法使用装饰器模式对现有Service进行包装,并且加入新的功能

4.Tapestry和JQuery在功能上存在兼容性的问题,如果想要两个框架协作运行,需要引入tapestry5-jquery组件,
组件在Tapestry上做了一些JQuery的功能扩展,具体可参考:http://tapestry5-jquery.com/
maven依赖如下:

[html] view plaincopy
 
  1. <dependency>  
  2.     <groupId>org.got5</groupId>  
  3.     <artifactId>tapestry5-jquery</artifactId>  
  4.     <version>3.3.1</version>  
  5. </dependency>  
  6. <repository>  
  7.     <id>devlab722-repo</id>  
  8.     <url>http://nexus.devlab722.net/nexus/content/repositories/releases</url>  
  9.     <snapshots>  
  10.         <enabled>false</enabled>  
  11.     </snapshots>  
  12. </repository>  
  13. <repository>  
  14.     <id>devlab722-snapshot-repo</id>  
  15.     <url>http://nexus.devlab722.net/nexus/content/repositories/snapshots</url>  
  16.     <releases>  
  17.         <enabled>false</enabled>  
  18.     </releases>  
  19. </repository>  

引入该框架后,jquery语句便可以被解析,因此无需在手动引入JQuery框架

5.Tapestry框架提供了面向组件的编程方法,其内部封装了很多组件,参考:http://tapestry.apache.org/component-reference.html
Tree组件的使用
视图:

[html] view plaincopy
 
  1. <t:tree t:model="model" t:node="treeNode" t:value="topic">  
  2.     <p:label>  
  3.         <t:if test="treeNode.leaf">  
  4.             <a id="${topic.href}" style="cursor:pointer">${treeNode.label}</a>  
  5.         </t:if>  
  6.         <t:if test="!treeNode.leaf">  
  7.             ${treeNode.label}  
  8.         </t:if>  
  9.     </p:label>  
  10. </t:tree>  

控制器:

[java] view plaincopy
 
  1. @Property  
  2. private TreeNode<Topic> treeNode;  
  3. @Property  
  4. private Topic topic;  
  5. public TreeModel<Topic> getModel(){  
  6.     return new TopicTreeModel();  
  7. }  


6.除了内置的组件之外,Tapestry还有一个比较特殊的组件:Layout布局组件,该组件是由开发人员来编写的
组件功能:声明界面的布局框架,供其他界面继承使用
组件使用场景:界面之间存在共同的元素(菜单导航、版权信息等),将这些共同的元素提取出来作为模版使用,功能类似于JSP的include标签
视图:

[html] view plaincopy
 
  1. <html xmlns="http://www.w3.org/1999/xhtml"  
  2.       xmlns:t="http://tapestry.apache.org/schema/tapestry_5_3.xsd"  
  3.       xmlns:p="tapestry:parameter">  
  4.     <head>  
  5.         <meta http-equiv="content-type" content="text/html; charset=utf-8"/>  
  6.         <title>${title}</title>  
  7.     </head>  
  8.     <body>  
  9.         <div>header<div>  
  10.         <t:body/><!--相当于java中的抽象方法,需要子界面去实现-->  
  11.         <div>footer<div>  
  12.     </body>  
  13. </html>  

控制器:

[java] view plaincopy
 
  1. public class Layout{  
  2.     @Property  
  3.     @Parameter(required = true, defaultPrefix = BindingConstants.LITERAL)  
  4.     private String title;  
  5. }  


7.组件的控制器类中经常会看到以@Parameter标注的属性用来描述组件参数
如同功能函数需要方法参数一样,组件也需要参数来决定其行为
如上面的Layout组件,其对外声明了一个‘title‘参数,使用该组件时可通过t前缀来指定title的值

[html] view plaincopy
 
  1. <html t:type="layout" t:title="index page"   
  2.         xmlns:t="http://tapestry.apache.org/schema/tapestry_5_3.xsd"  
  3.         xmlns:j="tapestry-library:jquery">  
  4.     <div>content<div>  
  5. </html>  

同时也看到,由于使用了Layout组件,界面无需在处理header和footer信息,只需覆盖<t:body/>标签中内容便可

组件在使用时,组件参数和类属性是双向绑定的,修改一方会级联影响到另一方,比如这里如果修改title属性值界面会发生变化,反之亦然

@Parameter标签对外提供了一些属性,作用分别如下:
required:参数是否必须指定
autoconnect:将属性值和Component的Id值绑定,如果类型一致
value:指定默认值(可绑定属性表达式)
cache:是否缓存参数值
defaultPrefix:默认绑定约束

8.在界面指定组件参数值时,只能是String形式的表达式,而组件属性可能是其他类型,因此需要进行语义转换
Tapestry提供了几种内置的转换方法,通过前缀的方式触发
asset:查找资源文件转换成Asset对象
context:查找webapp根目录下资源(<img src="http://www.mamicode.com/${context:images/icon.png}"/>)
literal:绑定字符串文本
message:加载properties文件中对应的key值
prop:绑定属性表达式(http://tapestry.apache.org/property-expressions.html)
var:绑定界面临时变量(<li t:type="loop" source="1..10" value="http://www.mamicode.com/var:index">${var:index}</li>)


9.在使用Layout组件时,或许会有个疑问。由于界面继承了Layout模版,因此只需要重写<t:body/>标签便可,但是如何才能引入额外的脚本和样式呢?
平时写界面,脚本都是在<head>里引入的,而通过Tapestry开发界面,脚本和样式的引入可在控制器类中进行声明

[java] view plaincopy
 
  1. @Import(stylesheet="context:styles/layout-default-latest.css"//引入CSS样式  
  2.     library={"context:javascripts/vendor/jquery.layout-latest.js","Layout.js"}) //引入js脚本,如不指定context前缀则表示相对路径  
  3. public class IndexPage{  
  4.     ......  
  5. }  


10.Tapestry在界面端遵循的是面向组件的开发方法,通常将不同的组件按模块进行划分,打包放入到不同的jar中
主程序如何才能识别这些jar,并调用其封装的组件?主要是通过manifest.mf配置文件来完成的。
文件中封装了这样一条元数据:Tapestry-Module-Classes: com.yourcompany.services.yourModule
Module类是每个模块的入口,主程序通过它来完成模块的加载,为了将Module中的组件暴露出去供其他Module使用,需要在Module类中声明如下方法:

[java] view plaincopy
 
  1. public static void contributeComponentClassResolver(Configuration<LibraryMapping> configuration){  
  2.     configuration.add(new LibraryMapping("moduleName""com.yourcompany"));  
  3. }  

自此,模块中的组件便可被其他Module使用,通过如下声明:

[html] view plaincopy
 
  1. <html xmlns:t="http://tapestry.apache.org/schema/tapestry_5_1_0.xsd"  
  2.   xmlns:m="tapestry-library:moduleName">  
  3.   ...  
  4.   <m:yourComp/>  
  5.   ...  
  6. </html>  

详细参考:http://tapestry.apache.org/component-libraries.html