当您向页面添加Ajax行为时,该页面将变为有状态的(Ajaxlink使用AjaxEventBehavior)。这是因为当您单击链接时,Wicket会尝试在服务器上找到页面实例,然后在其中找到链接组件,最后执行其回调方法-
例如onClick()。如果不存储页面,则无法找到ajax行为实例并执行其回调方法。
您可以使用Jolira的Ajax行为和组件(https://github.com/jolira/wicket-stateless)。它们的工作原理略有不同-
当您单击Jolira的Ajaxlink时,Ajax调用将创建页面的全新实例,在其中找到新创建的StatelessAjaxlink,执行其回调方法,最终使用AjaxRequestTarget为Ajax响应添加组件/
javascript,丢弃新创建的页面实例(已被垃圾回收)。下一个Ajax请求对一个全新的页面实例执行相同的操作。
有人会问:“为什么Jolira的代码不在Wicket核心中?”
-因为它提供了部分解决方案。例如:单击statelessAjaxlink1创建一个新的Page,在StatelessAjaxlink的新实例上执行onClick(),其中PanelA被PanelB替换,并将此面板(PanelB)添加到AjaxRequestTarget。简而言之:单击此链接将替换页面中面板的主体。如果PanelB内部有一个StatelessAjaxlink2,则此链接是找不到的。为什么呢
因为单击它会创建Page的新实例,并且此新实例将具有PanelA,而不是PanelB,因此无法找到StatelessAjaxlink2执行其onClick()方法。
如果您的场景足够简单,并且Jolira的组件可以满足您的要求,则可以使用它们。请注意,更复杂的方案可能会失败。



