我有一个Wicket页面,其中包含一些应该通过AJAX更新的组件。我有以下AjaxBehavior:
private class MyAjaxBehavior extends AbstractDefaultAjaxBehavior {
@Override
public void renderHead(IHeaderResponse response) {
super.renderHead(response);
response.renderOnLoadJavascript("wicketAjaxPost(\"" + getCallbackUrl() + "\")");
}
@Override
public void onConfigure(Component component) {
firstComponent.setOutputMarkupId(true);
secondComponent.setOutputMarkupId(true);
}
@Override
protected void respond(AjaxRequestTarget target) {
firstComponent.replaceWith(createFirstComponent());
target.addComponent(firstComponent);
secondComponent.replaceWith(createSecondComponent());
target.addComponent(secondComponent);
}
}
我有一个像这样的组件层次结构:
Page
- fragment1
- fragment1-1
- firstComponent
- secondComponent
在AJAX回调之后问题是firstComponent
永远不会刷新。 secondComponent
已正确更新。我试图将firstComponent
移到frament1-1
(只是实验)并且它有效!我尝试使用一些额外的片段来包裹firstComponent
,但它没有帮助。
我试图调试Wicket' AjaxRequestTarget.respondComponent()
。有以下代码:
// Initialize temporary variables
final Page page = component.findParent(Page.class);
if (page == null)
{
// dont throw an exception but just ignore this component, somehow
// it got
// removed from the page.
// throw new IllegalStateException(
// "Ajax request attempted on a component that is not associated
// with a Page");
LOG.debug("component: " + component + " with markupid: " + markupId +
" not rendered because it was already removed from page");
return;
}
对于page
和firstComponent
, secondComponent
为空,但第二个以某种方式重新呈现。
为什么firstComponent
未重新呈现的任何想法?我应该去哪里挖?我使用Wicket 1.4.22。
UPD
我尝试将新组件添加到target
而不是旧组件。它在页面上创建新组件但不刷新旧组件。所以我在页面上有两个组件而不是一个。由于某种原因,它也打破了HTML标记结构。像这样:
<div>
<div id="generated">new component is added here</div>
<table>
...
<tr>old component</tr>
</table>
</div>
firstComponent
的我的检票口标记如下:
<div>
<table class="summary" style="width: 100%">
<tr>
<div wicket:id="firstComponent" />
</tr>
</table>
</div>
...
<wicket:fragment wicket:id="firstComponentFragment">
<th>title</th>
<td><span wicket:id="someText"></span></td>
</wicket:fragment>
所以你可以看到新组件被添加到表外。
答案 0 :(得分:1)
有时将父组件(例如表单本身)添加到ajax响应目标会更容易,因此您可以确定其下的所有内容都已更新。因此没有重复或缺少更新。仅在需要性能时才需要更新特殊组件。即使你可以定义一个更新的包装容器,只是为了确保删除旧的标记。
答案 1 :(得分:0)
您必须更新新创建的组件:
@Override
protected void respond(AjaxRequestTarget target) {
Component old = firstComponent;
firstComponent = createFirstComponent();
old.replaceWith(firstComponent);
target.addComponent(firstComponent);
}
更新:您在<div>
标记内不能有<table>
,或者浏览器会在表格之外附加更新标记。