为了避免表单重新提交,我使用了POST-Redirect-GET模式,它工作正常。现在在我的注册页面(成功页面)上,它显示操作消息"已成功插入审核!当用户刷新页面时,我想删除此消息。
我在 JSP 页面上的代码:
<s:if test="hasActionMessages()">
<div class="success-mesg" id="success-mesg">
<s:iterator value="actionMessages">
<s:property value="top" />
</s:iterator>
</div>
</s:if>
在支柱上.xml:
<action name="insertReview" class = "com.tenkinfo.streamlinedmapnsav.ui.action.WriteReviewAction" method="insertReview" >
<result name="insertReviewDone" type="redirect" >insertReviewDone</result>
<result name="input" type="tiles">display.writeReview.page</result>
</action>
<action name="insertReviewDone" class = "com.tenkinfo.streamlinedmapnsav.ui.action.WriteReviewAction" method="insertReviewDone" >
<result name="success" type="tiles" >display.writeReview.page</result>
</action>
在操作类中:
public String insertReviewDone(){
addActionMessage("Write review is successful");
return "success";
}
编辑:
在实施亚历山大M建议的答案后,我遇到了以下问题:
<s:form name="insertReview" action="insertReview" id="insertReview"
theme="simple" enctype="multipart/form-data">
<div class="content-area">
<h1>
Review
<s:property value="businessName" />
</h1>
<s:if test="hasActionMessages()">
<div class="success-mesg" id="success-mesg">
<s:iterator value="actionMessages">
<s:property value="top" />
</s:iterator>
</div>
</s:if>
刷新上述代码中的页面后,业务名称被删除且不显示。任何帮助将不胜感激。
使用 Message Store Interceptor
将操作消息存储在insertReview
中,并在insertReviewDone
操作中检索它。在返回结果时insertReview
方法中添加操作消息insertReviewDone
。
还可以使用 redirectAction
结果重定向到操作而不是redirect
。
<action name="insertReview" class = "com.tenkinfo.streamlinedmapnsav.ui.action.WriteReviewAction" method="insertReview">
<interceptor-ref name="store">
<param name="operationMode">STORE</param>
</interceptor-ref>
<interceptor-ref name="defaultStack" />
<result name="insertReviewDone" type="redirectAction">insertReviewDone</result>
<result name="input" type="tiles">display.writeReview.page</result>
</action>
<action name="insertReviewDone" class = "com.tenkinfo.streamlinedmapnsav.ui.action.WriteReviewAction" method="insertReviewDone" >
<interceptor-ref name="store">
<param name="operationMode">RETRIEVE</param>
</interceptor-ref>
<interceptor-ref name="defaultStack" />
<result name="success" type="tiles">display.writeReview.page</result>
</action>
另一种方法,技术性不如@AleksandrM提出的(好的)方法,但适用于那里的每个框架,而不仅仅是 Struts2,就是放置这个
<script>
$(document).ready(function() {
window.history.pushState("","", location.href);
});
</script>
在您的<head>
部分。但是,它不适用于没有HTML5功能的旧浏览器。
注意:jQuery 部分不是强制性的,它只是用来确保它在页面加载后运行,你可以在没有它的情况下运行 HTML5 pushState()
。