有没有人找到一种在富有时显示加载消息的方法:dataTable加载?
我发现如果支持DataModel的加载操作需要时间,则会导致请求花费时间。是否是在此加载期间向用户显示消息的有效方法?
我正在使用Richfaces 3.3.3。
答案 0 :(得分:2)
您可以使用a4j:status
。有关详细信息,请参阅Exadel livedemo:http://livedemo.exadel.com/richfaces-demo/richfaces/status.jsf?c=status&tab=usage
如果您只需要在数据表互动上显示消息,则可以a4j:status
限制a4j:region
的区域:
<a4j:region>
<a4j:status startText="Loading. Please wait..." >
<rich:dataTable .../>
</a4j:region>
<强>更新强> 对于某些内容的延迟加载,可以使用以下方法。 创建facelet(或组件):
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:c="http://java.sun.com/jstl/core"
xmlns:a4j="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich">
<h:panelGroup id="lazyP#{id}" layout="block">
<ui:fragment rendered="#{lazy.isRendered(id)}">
<ui:insert name="lazy"/>
</ui:fragment>
<ui:fragment rendered="#{not lazy.isRendered(id)}">
<h:outputText value="Loading..."/>
<a4j:region>
<a4j:jsFunction name="loadData#{id}" reRender="lazyP#{id}"
action="#{lazy.release(id)}"
limitToList="true"
ajaxSingle="true" eventsQueue="lazyQueue"/>
</a4j:region>
<script type="text/javascript">
jQuery(document).ready(function() {
loadData#{id}();
});
</script>
</ui:fragment>
</h:panelGroup>
lazy
是bean的引用(我使用页面范围),它存储了渲染内容和非渲染内容的地图(release
方法标记项目为渲染)。
然后您可以使用以下内容:
<ui:decorate template="lazyLoad.xhtml">
<ui:param name="id" value="someId"/>
<ui:define name="lazy">
<rich:dataTable ... />
</ui:define>
</ui:decorate>