检票口 - 使用 AJAX 刷新组件 - 文档元素后的垃圾

Wicket - refresh component using AJAX - junk after document element

本文关键字:元素 文档 刷新 使用 AJAX 组件      更新时间:2023-09-26

我正在尝试使用 AJAX 刷新页面上的组件。下面是一些代码:

    private class MyAjaxBehavior extends AbstractDefaultAjaxBehavior {
        private final DataView<Something> dataView;
        private MyAjaxBehavior(DataView<Something> dataView) {
            this.dataView = dataView;
        }
        @Override
        protected void respond(AjaxRequestTarget target) {
            // here I do something with dataView...
            MarkupContainer container = dataView.getParent();
            dataView.setOutputMarkupId(true);
            container.setOutputMarkupId(true);
            dataView.renderComponent();
            container.renderComponent();
            target.addComponent(container);
        }
    }

我可以使用javascript functio wicketAjaxPost(<callback url>)调用respond()方法。但是我的页面上没有任何变化。当我打开javascript控制台时,我看到以下错误:junk after document element。当我重新加载页面时,我的更改是可见的,所以这只是关于 AJAX。我做错了什么?我认为这是因为我的 HTML 无效;那么如何让用户的浏览器忽略验证错误呢?

我正在使用检票口 1.4.22。

不要调用 #renderComponent(),当它将容器呈现为 ajax 响应时,wicket 会调用它。

从 #respond() 调用 #setOutputMarkupId(true) 为时已晚,组件必须在第一个 Ajax 请求之前输出其 markupId。你可以从你的行为的 #onConfigure() 调用 container#setOutputMarkupId(true)。