Wicket - 使用 AJAX 刷新组件 - 文档元素后的垃圾
Wicket - refresh component using AJAX - junk after document element
我正在尝试使用 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 函数 wicketAjaxPost(<callback url>)
调用 respond()
方法。但我的页面上没有任何变化。当我打开 javascript 控制台时,我看到以下错误:junk after document element
。当我重新加载页面时,我的更改是可见的,所以这大约是 AJAX。我究竟做错了什么?我认为这是因为我的无效 HTML;那么如何让用户的浏览器忽略验证错误?
我正在使用 Wicket 1.4.22。
不要调用#renderComponent(),wicket 会在将容器渲染到ajax 响应中时调用它。
从#respond() 调用#setOutputMarkupId(true) 为时已晚,组件必须在第一个 Ajax 请求之前输出它们的 markupId。
您可以从行为的#onConfigure() 调用容器#setOutputMarkupId(true)。
我正在尝试使用 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 函数 wicketAjaxPost(<callback url>)
调用 respond()
方法。但我的页面上没有任何变化。当我打开 javascript 控制台时,我看到以下错误:junk after document element
。当我重新加载页面时,我的更改是可见的,所以这大约是 AJAX。我究竟做错了什么?我认为这是因为我的无效 HTML;那么如何让用户的浏览器忽略验证错误?
我正在使用 Wicket 1.4.22。
不要调用#renderComponent(),wicket 会在将容器渲染到ajax 响应中时调用它。
从#respond() 调用#setOutputMarkupId(true) 为时已晚,组件必须在第一个 Ajax 请求之前输出它们的 markupId。 您可以从行为的#onConfigure() 调用容器#setOutputMarkupId(true)。