我从使用Tapestry构建的现有webapp开始。
我无法弄清楚我需要的Javascript放在哪里。
基本上这个应用程序有一个页面将数据捕获到文本区域,我想要包含一个javascript库来处理该文本区域。
将什么是添加到Tapestry应用程序的方法?任何样本或链接将非常感激。
洲! :)
答案 0 :(得分:4)
要向组件添加一些客户端行为,您通常会在应用的mixins
包中创建一个component mixin类:
package my.tapestry.basepackage.mixins;
public class TextAreaResizer {
}
在您的组件模板中,您将mixin添加到文本区域,如下所示:
<textarea t:type="TextArea" t:value="..." t:mixins="TextAreaResizer" />
要将JS库加载到页面中,您可以在mixin上使用@IncludeJavaScriptLibrary注释,如下所示:
@IncludeJavaScriptLibrary("context:textarearesizer/js/textarearesizer.js")
public class TextAreaResizer {
}
如果你需要运行一些初始化代码,那就是通过RenderSupport服务完成的,如下所示:
@IncludeStylesheet("context:textarearesizer/css/textarearesizer.css")
@IncludeJavaScriptLibrary("context:textarearesizer/js/textarearesizer.js")
public class TextAreaResizer {
@Inject
private RenderSupport renderSupport;
@InjectContainer
private TextArea textArea;
@AfterRender
void addScript() {
this.renderSupport.addScript(
"new TextAreaResizer('%s');", this.textArea.getClientId());
}
}
在这种情况下,我还将文本字段组件注入mixin类,因为我需要它的客户端ID。