好了。这是我的第一个wicket应用程序,我正在尝试使用pushpanel示例集成icepush。
我想做的是通过调用另一个类的updatePanel(String-content)方法将更新推送到面板。
这是代码。
在我的扩展PushPanel中,我有:
public AsyncCommsPanel(String id) {
super(id);
this.setOutputMarkupId(true);
ajaxForm = new Form("ajaxForm");
ajaxForm.setOutputMarkupId(true);
ajaxForm.add(textStore = new Label("textStore",""));
ajaxForm.add(new AjaxButton("updateButton") {
@Override
protected void onSubmit(AjaxRequestTarget target, Form form) {
System.out.println("Update button pressed!");
/* CODE TO PULL NEW DATA FROM ELSEWHERE */
/* UPDATE TAKES TIME SO HAS ITS OWN CALLBACK */
}
@Override
protected void onError(AjaxRequestTarget target, Form<?> form) {
System.out.println("Update button error.");
}
});
add(ajaxForm);
}
@Override
protected void pushCallback(AjaxRequestTarget target) {
target.add(ajaxForm);
}
public void updatePanel(String updateString) {
/* THIS METHOD SHOULD ALLOW THE PANEL TO BE UPDATED FROM ELSEWHERE */
if (textStore != null) ajaxForm.remove(textStore);
ajaxForm.add(textStore = new Label("textStore", updateString));
push();
}
当我尝试从数据采集程序的回调方法调用"updatePanel"方法时,我会得到以下异常:
ERROR (SelectorManager.run): org.apache.wicket.WicketRuntimeException: No RequestCycle is currently set!
at org.apache.wicket.Component.getRequest(Component.java:1831)
at org.apache.wicket.markup.html.WebPage.dirty(WebPage.java:315)
at org.apache.wicket.Page.dirty(Page.java:288)
at org.apache.wicket.Page.componentRemoved(Page.java:948)
at org.apache.wicket.MarkupContainer.removedComponent(MarkupContainer.java:1422)
at org.apache.wicket.MarkupContainer.remove(MarkupContainer.java:612)
at uk.ac.warwick.collabtex.AsyncCommsPanel.updatePanel(AsyncCommsPanel.java:107)
at uk.ac.warwick.collabtex.Editor$1.updateSuccess(Editor.java:98)
欢迎来到异步世界:-)ThreadLocals(应用程序、会话和ThreadLocal)仅在处理http请求线程(也称为工作线程)期间可用。因此有两个问题:1)启动自己的线程会丢失ThreadLocal,2)即使导出了它们,当作业完成时,响应也有可能已经关闭。我不确定IcePush是如何工作的,但我认为这是最好的选择-提交任务,在应用程序中保留对它的引用(例如Map),然后启动ajax计时器行为,定期询问futureTask.isDone(),当它返回true时,您需要更改层次结构(我在stacktrace中看到对MarkupContainer#remove()的调用)。