我有一个简单的登录页面,如果登录不成功,则显示一条消息。我想让这个消息在5秒后淡出,但是我不能让它工作。
登录部分(删除了大部分不相关的内容):
<h:inputText title="Name" value="#{authBean.name}" id="username" />
<h:inputSecret title="Password" value="#{authBean.password}" id="password" />
<p:commandButton id="loginButton" action="#{authBean.loginAndRedirect}"
update="@form" value="Login" />
<h:message id="messages" for="login:username" />
我已经试过了:
在Firebug命令行中输入的命令运行良好:$('[id$=messages]').fadeOut();
现在我需要一个定时器来触发它:
像这样在按钮上设置回调不起作用(没有效果,没有错误):
<p:commandButton ... oncomplete="setTimeout(5000, '$('[id$=messages]').fadeOut())" ... />
我已经尝试了onclick
和oncomplete
,但没有效果,没有错误。
尝试在message
元素上使用primfaces效果(包装的JQuery效果):
<h:message id="messages" for="login:username" errorClass="errorMessage">
<p:effect type="fadeout" event="load" delay="5000">
<f:param name="mode" value="'hide'" />
</p:effect>
</h:message>
在setTimeout()
中缺少function
闭包。此外,调用函数比使用内联JavaScript更好。它更容易阅读和调试。
。
<p:commandButton ... oncomplete="fadeoutfunction()" ... />
function fadeoutfunction(){
setTimeout(function(){
$('[id$=messages]').fadeOut();
},5000);
}
<p:commandButton ...
oncomplete="setTimeout(function(){$('[id$=messages]').fadeOut()},'5000')" ... />