Tapestry5新特性 博客分类: Tapestry5 TapestryJavaApachewicketIOC
程序员文章站
2024-02-20 17:39:16
...
官话版:
一、组件类不再需要继承基类;
二、组件类不再是抽象类,而是纯粹的简单的POJO(plain old Java objects)
三、不再使用XML配置文件和组件定义文件(.page,.jwc),所有的配置信息使用注释(annotations)实现。
四、组件类和模版的任何改变都可以马上反应出来,不需要任何重启。
五、Blazing(翻译:炽燃的, 强烈的)速度,比Tapestry4的速度更快。
白话版:
一、组件类可以不受框架限制,不需要继承基类,也不需要定义成抽象的,生命周期完全使用注释来实现。
@ComponentClass相当于标记extends BasePage
@BeginRender相当于implements PageBeginRenderListener
二、配置也完全用注释实现了,包括IOC容器,也就是基于注释配置的IOC容器,放弃了hivemind。
module和service定义类:
需要注入的类:
也就是buildIndexer方法为固定写法,格式为build{serviceId}。当然还有hivemind的影子,比如多module和contribute等等。
三、页面和组件的配置文件都可以完全使用注释来实现,这个特性在Tapestry4中已经可以使用了,没什么新奇的,不过完全在注释中配置,看着代码有点乱,写多了就开始怀疑这还是java类么。
例子:
四、Tapestry 5自动重新加载改变过的类和摸板,这个应该是脚本语言的特性,但从说明中好像只有组件类有此特性,其他的类可能还是需要重启。不过这已经是很大的进步了,用java实现了脚本语言的动态载入功能。现在随着越来越多的对classloader的研究,对java的使用也越来越深入了。
五、关于性能,没有了解析配置文件的花销,估计Tapestry4中的初始化慢的问题应该可以解决了。如果说比纯servlet和jsp快的话,那就要归功于cache的使用了。
总起来说Tapestry5还是值得期待的,现在还处于开发阶段,许多特性都是没有定型的,如果有更好的概念,估计HLS会加进去了(PS:真是服了他了,Tapestry4.1加入了Ajax的功能,正要研究呢,却又推出了这个T5,搞的我心痒痒的,不过好久没有这种看到新特性的兴奋了)。其中提出了许多的新概念还是很值得借鉴的,包括基于注释的IOC容器,现在spring也推出spring-annotation包了;基于注释的页面显示生命周期定义,@SetupRender、 @BeginRender、 @BeforeRenderBody等,这样整个类除了注释外,没有任何侵入性了,把注释去掉就是个简单的java类,不需要继承,不需要实现固定方法。而且Tapestry5的生命周期基于状态机和队列算法,而不是尾递归,这样周期可以定义的很细,而且实现起来也简单了。
一、组件类不再需要继承基类;
二、组件类不再是抽象类,而是纯粹的简单的POJO(plain old Java objects)
三、不再使用XML配置文件和组件定义文件(.page,.jwc),所有的配置信息使用注释(annotations)实现。
四、组件类和模版的任何改变都可以马上反应出来,不需要任何重启。
五、Blazing(翻译:炽燃的, 强烈的)速度,比Tapestry4的速度更快。
白话版:
一、组件类可以不受框架限制,不需要继承基类,也不需要定义成抽象的,生命周期完全使用注释来实现。
package org.example.myapp.components; import org.apache.tapestry.MarkupWriter; import org.apache.tapestry.annotations.ComponentClass; import org.apache.tapestry.annotations.BeginRender; @ComponentClass public class HelloWorld { @BeginRender void renderMessage(MarkupWriter writer) { writer.write("Bonjour from HelloWorld component."); } }
@ComponentClass相当于标记extends BasePage
@BeginRender相当于implements PageBeginRenderListener
二、配置也完全用注释实现了,包括IOC容器,也就是基于注释配置的IOC容器,放弃了hivemind。
module和service定义类:
package org.example.myapp.services; import org.apache.tapestry.ioc.annotations.Id; @Id("myapp") public class MyAppModule { public static Indexer buildIndexer() { return new IndexerImpl(); } }
需要注入的类:
@Inject("service:myapp.Indexer") private Indexer indexer;
也就是buildIndexer方法为固定写法,格式为build{serviceId}。当然还有hivemind的影子,比如多module和contribute等等。
三、页面和组件的配置文件都可以完全使用注释来实现,这个特性在Tapestry4中已经可以使用了,没什么新奇的,不过完全在注释中配置,看着代码有点乱,写多了就开始怀疑这还是java类么。
例子:
package org.example.app.pages; import org.apache.tapestry.annotations.Component; import org.apache.tapestry.annotations.ComponentClass; import org.example.app.components.Count; @ComponentClass public class Countdown { @Component(parameters = { "start=5", "end=1", "value=countValue" }) private Count _count; private int _countValue; public int getCountValue() { return _countValue; } public void setCountValue(int countValue) { _countValue = countValue; } }
四、Tapestry 5自动重新加载改变过的类和摸板,这个应该是脚本语言的特性,但从说明中好像只有组件类有此特性,其他的类可能还是需要重启。不过这已经是很大的进步了,用java实现了脚本语言的动态载入功能。现在随着越来越多的对classloader的研究,对java的使用也越来越深入了。
五、关于性能,没有了解析配置文件的花销,估计Tapestry4中的初始化慢的问题应该可以解决了。如果说比纯servlet和jsp快的话,那就要归功于cache的使用了。
总起来说Tapestry5还是值得期待的,现在还处于开发阶段,许多特性都是没有定型的,如果有更好的概念,估计HLS会加进去了(PS:真是服了他了,Tapestry4.1加入了Ajax的功能,正要研究呢,却又推出了这个T5,搞的我心痒痒的,不过好久没有这种看到新特性的兴奋了)。其中提出了许多的新概念还是很值得借鉴的,包括基于注释的IOC容器,现在spring也推出spring-annotation包了;基于注释的页面显示生命周期定义,@SetupRender、 @BeginRender、 @BeforeRenderBody等,这样整个类除了注释外,没有任何侵入性了,把注释去掉就是个简单的java类,不需要继承,不需要实现固定方法。而且Tapestry5的生命周期基于状态机和队列算法,而不是尾递归,这样周期可以定义的很细,而且实现起来也简单了。