2

我在很多地方都研究过这个话题并找到了一些方法。在这个特定场景中,我使用了https://cwiki.apache.org/confluence/display/WICKET/Calling+Wicket+from+Javascript文章作为参考。

我在 Java 中所做的,

public class HomePage extends WebPage {
    private static final long serialVersionUID = 1L;

    public HomePage(final PageParameters parameters) {
        super(parameters);


        final AbstractDefaultAjaxBehavior behave = new AbstractDefaultAjaxBehavior() {
            protected void respond(final AjaxRequestTarget target) {
                target.add(new Label("foo", "Yeah I was just called from Javascript!"));
            }

            public void renderHead(Component component,IHeaderResponse response){

                String componentMarkupId = component.getMarkupId();
                String callbackUrl = getCallbackUrl().toString();

                response.render(JavaScriptHeaderItem.forScript("var componentMarkupId='"+componentMarkupId+"'; var callbackUrl='"+callbackUrl+"';","values"));
            }
        };

        add(behave);

    }

}

和我的 HomePage.html,

<!DOCTYPE HTML>
<html>
<body>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
<script type="text/javascript">
    $(function() {
        var wcall = Wicket.Ajax.get({ u: '${callbackUrl}' + '' });
        alert(wcall);
    });
</script>
</body>
</html>

我试图做的是使用我初始化的变量调用 get ajax 方法。但是当我的页面加载时,在萤火虫控制台中它说,

ReferenceError: Wicket is not defined
[Break On This Error]    

var wcall = Wicket.Ajax.get({ u: '${callbackUrl}' + '' });

这里出了什么问题?

还有其他从 Javascript 调用 Java 函数的好方法吗?

4

2 回答 2

1

您需要将 wicket javascript 添加到页面中,通常是通过确保像 renderHead 这样的覆盖方法进行 super.renderHead 调用。

于 2013-07-04T09:12:33.893 回答
0

Wicket 6.x:在类中扩展 AbstractDefaultAjaxBehavior

@Override
public void renderHead(Component component, IHeaderResponse response) {
    String callbackUrl = getCallbackUrl().toString();

    StringBuffer script = new StringBuffer();
    script
            .append("var callbackUrl = '").append(callbackUrl).append("';\n")
            .append("someJavaScriptCode();\n")
            .append("Wicket.Ajax.get({u: callbackUrl});");

    response.render(OnDomReadyHeaderItem.forScript(script.toString()));
}
于 2018-08-03T12:25:47.773 回答