3

为了避免重新提交表单,我使用了 POST-Redirect-GET 模式,它工作正常。现在在我的注册页面(成功页面)上显示 ActionMessage “评论插入成功!”。当用户刷新页面时,我想删除此消息。

我在 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>

在 struts.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";
}

编辑 :

在实施 Aleksandr 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>

刷新上面代码中的页面后,业务名称被删除并且不显示。任何帮助将不胜感激。

4

2 回答 2

3

用于在您的操作Message Store Interceptor中存储操作消息insertReview并在您的操作中检索它insertReviewDone。返回结果insertReview时在方法中添加操作消息。insertReviewDone

还使用redirectActionresult 重定向到 action 而不是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>
于 2013-09-20T10:33:49.277 回答
1

另一种方法,比@AleksandrM 提出的(好)方法技术含量低,但适用于那里的每个框架,不仅是 Struts2,是放置这个

<script>
    $(document).ready(function() {
        window.history.pushState("","", location.href);
    });
</script>

在你的<head>部分。但是,它不适用于没有 HTML5 功能的旧浏览器。

注意:jQuery 部分不是强制性的,它只是用来确保它在页面加载后运行,你可以在pushState()没有它的情况下运行 HTML5。

于 2013-09-20T12:21:31.013 回答