迁移到wicket 1.5 - jQuery,jGrowl和ajax问题

时间:2015-05-12 14:12:54

标签: jquery ajax wicket wicket-1.5

将wicket从1.4迁移到wicket 1.5后,我发现了一个非常奇怪的问题 - 我的ajax"字段"不起作用,并且我的jQuery和jGrowl库存在错误(通过firebug找到)。

在阅读migration guide后,我更改了我的* .java文件,其中包含了JS库(我包含了#34; main"类之一):

@Override
    public void renderHead(IHeaderResponse response) {
        // JQUERY
        //val header = JSLib.getHeaderContribution(VersionDescriptor.alwaysLatest(Library.JQUERY));
        //header.renderHead(response);
        //val header1 = JSLib.getHeaderContribution(VersionDescriptor.alwaysLatest(Library.JQUERY_UI));
        //header1.renderHead(response);
        response.renderJavaScriptReference(new CommonResourceRef("js/jquery-1.4.2.min.js"));
        response.renderJavaScriptReference(new CommonResourceRef("js/jquery-ui-1.8.4.custom.min.js"));

        // MSDROPDOWN
        response.renderJavaScriptReference(new CommonResourceRef("js/jquery.msdropdown.js"));
        response.renderJavaScriptReference(new CommonResourceRef("js/languageDropDown.js"));
        response.renderCSSReference(new CommonResourceRef("css/msdropdown.css"));

        // JGROWL
        response.renderJavaScriptReference(new CommonResourceRef("js/jquery.jgrowl_minimized.js"));
        response.renderCSSReference(new CommonResourceRef("css/jquery.jgrowl.css"));
        response.renderCSSReference(new CommonResourceRef("css/jgrowl-page.css"));     
        response.renderOnLoadJavaScript("$(document).bind('keydown', function(e) { return submitButtonOnEnter(e); });");

        // disables warning on page leaving with displayed modal (if unloadConfirmation == false)
        if (!unloadConfirmation)
            response.renderOnLoadJavaScript("Wicket.Window.unloadConfirmation = false;");
    }

在我的一个页面上,我确实包含了这些库(再次使用firebug进行检查)但是我确实收到了这些错误:

  

TypeError:$ .jGrowl不是函数
  Wicket.Event.add(窗口," domready",function(event){   $ .jGrowl('靠近');;});

     

TypeError:$(...)为空
  $(" #middlebar> .menu> li> a")。click(function(){

     

TypeError:$(...)。bind不是函数   ... t.add(窗口,"加载",功能(事件){$(文档).bind(' keydown',   功能(e)......

至于我的ajax字段,它们不起作用(当我提交字段时,没有任何反应)。我注意到这个项目正在使用AjaxRequestTarget(meaby我迁移错了吗?)。不幸的是,我对ajax如何与wicket一起工作知之甚少,而我只能找到这个,我相信是在创造ajax"问题"。

public class PageAjaxEventBehavior extends AjaxEventBehavior {
[...]
    public void renderHead(IHeaderResponse response) {
        CharSequence handler = Strings.replaceAll(Strings.escapeMarkup(getEventHandler().toString()), "'", "'");
        String jqueryCall = String.format("$.ajax({ url: '%s', success: function(data) { $('.result').html(data); alert('Load was performed.'); } });",
                                          getCallbackUrl());

        String eventHandler = String.format("$(window).bind(\"%s\", function() {%s;});", getEvent(), jqueryCall);

        if (!closed)
            JavaScriptUtils.writeJavaScript(RequestCycle.get().getResponse(), eventHandler);

        closed = true;
    }
[...]
}

我不知道我还应该包括什么,所以如果你认为这个问题遗失了,请告诉我。请注意,在wicket 1.4中,everythink正常工作。

我还注意到Wicket.Event.add(window, "domready", function(event) { $.jGrowl('close');;});在包含jGrowl库之前在我的页面上呈现,在1.4之后呈现。

1 个答案:

答案 0 :(得分:2)

尝试在方法中添加super.renderHead(response)作为第一行。