在 PRG 模式中,如何在刷新成功页面上删除操作消息



为了避免表单重新提交,我使用了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()

最新更新