0

我想在用户空闲时自动更新数据表(在客户端)。我将 Primefaces 3.5 与 glassfish 一起使用,我的想法如下:

boolean autoUpdate在 bean 中有变量。用户可以打开/关闭自动更新。

我创建了两个组件:p:pollp:idleMonitor.

idleMonitor两个事件,触发更新

<p:ajax event="idle" oncomplete="myPoll.start();" />
<p:ajax event="active" oncomplete="myPoll.stop();" />

这部分没问题。问题是,如何禁用idleMonitorwhenautoUpdate设置为False?当我做

<h:panelGroup id="updatePanel" rendered="#{cc.attrs.bean.autoUpdate}">
....
</h:panelGroup>

它只有在我开始时才有效,autoUpdate = false而且我只能切换一次模式。渲染后无法更改。我也试过

<p:ajax event="idle" oncomplete="#{cc.attrs.bean.autoUpdate ? 'myPoll.start();' : ''}" />

但它也没有工作。#{cc.attrs.bean.autoUpdate}永远不会改变。即使我在上面调用 upadte,我也可以看到变量在另一个地方发生了变化。

所以,我的问题是:有什么方法可以在渲染后禁用 idleMonitor?或者对于空闲用户的可选定期更新,更好的解决方案是什么?

4

1 回答 1

0

您的 autoUpdate 变量仅在渲染时进行评估。(在页面加载时)

#{cc.attrs.bean.autoUpdate}

这就是为什么js不知道它的修改。

方案一,重新渲染一段js代码:

<p:ajax event="idle" update="afterIdle" />
<h:panelGroup id="afterIdle">
 <h:outputScript>
  if ('#{cc.attrs.bean.autoUpdate}' == 'true') 
   myPoll.start();
 </h:outputScript>
</h:panelGroup>

解决方案 2:在 autoUpdate 上保持 js 变量的更新(不知何故,例如使用 remoteCommand):

<p:ajax event="idle" oncomplete="myFunction()" />
<script type="text/javascript">
 function myFunction(){
  if (jsAutoUpdate) myPoll.start();
 }
</script>

解决方案 3:primefaces idleMonitor 小部件有一个 stop() 函数,可以停止空闲监控。

于 2013-10-28T10:45:01.060 回答