我有类似的东西:
<p:inputText...>
<p:ajax event="keyup" update="somefield" listener="#{someBean.doSomething}"/>
</p:inputText>
但我不想在每次按键时都执行 Ajax 请求,我想在用户停止写入后半秒执行请求。
我在另一个问题中看到这个问题在 jQuery 中得到了解决:如何延迟 .keyup() 处理程序直到用户停止键入? https://stackoverflow.com/questions/1909441/jquery-keyup-delay
我想知道是否可以在 primefaces 上执行此操作,或者如何适应 jQuery 问题的解决方案。
我正在使用 PrimeFaces 3.0.M4。
先感谢您。
如果使用 Primefaces 5.x,则有delay
属性中的p:ajax
用于此目的的标签。所以它是这样完成的:
<p:inputText...>
<p:ajax event="keyup" delay="1000" listener="#{someBean.doSomething}"
update="somefield" process="@this" />
</p:inputText>
如果没有,你可以使用它来实现f:ajax
代替p:ajax
(是的,它适用于p:inputText
, too). f:ajax
添加了对队列控制 http://jdevelopment.nl/jsf-22/#1050从 JSF 2.2 开始。所以代码看起来像:
<p:inputText...>
<f:ajax event="keyup" delay="1000" listener="#{someBean.doSomething}"
render="somefield" execute="@this" />
</p:inputText>
也可以看看:
- Primefaces 5.0p:ajax javadoc http://www.primefaces.org/docs/vdl/5.0/core/
- JSF 2.2 文档f:ajax http://docs.oracle.com/javaee/7/javaserver-faces-2-2/vdldocs-facelets/f/ajax.html
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)