将JavaScript添加到Tapestry应用程序的方法是什么?

时间:2010-08-19 22:16:00

标签: java javascript tapestry web-applications

我从使用Tapestry构建的现有webapp开始。

我无法弄清楚我需要的Javascript放在哪里。

基本上这个应用程序有一个页面将数据捕获到文本区域,我想要包含一个javascript库来处理该文本区域。

将什么是添加到Tapestry应用程序的方法?任何样本或链接将非常感激。

洲! :)

1 个答案:

答案 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。

另请查看AJAX & Javascript section of the T5 docs