Spring MVC Thymeleaf在一个表单中的多个提交按钮

今天遇见一个form需要两个button提交显示不同Controller的需求

一开始解决思路:


我有一个HTML页面的一个窗体和2个按钮的片段:

<form action="#" data-th-action="@{/action/edit}" data-th-object="${model}" method="post">
    <button type="submit" name="action" value="save">save</button>
    <button type="submit" name="action" value="cancel">cancel</button>
</form>

以及控制器:

@RequestMapping(value="/edit", method=RequestMethod.POST)
public ModelAndView edit(@ModelAttribute SomeModel model, 
        @RequestParam(value="action", required=true) String action) {
    if (action.equals("save")) {
        // do something here     
    }
    if (action.equals("cancel")) {
       // do another thing
    }
    return modelAndView;
}

后来网上查阅大牛的思路:


您可以使用params变量创建具有不同@RequestMappings的单独方法。

@RequestMapping(value="/edit", method=RequestMethod.POST, params="action=save")
public ModelAndView save() {}
@RequestMapping(value="/edit", method=RequestMethod.POST, params="action=cancel")
public ModelAndView cancel() {}

使用th:formactionon submit button这是工作在多少你有submit button和这也是usefull给予更多的链接到一个表单与不同的submit button

<form action="#"  class="form" th:action="@{'/publish-post/'+${post.id}}" method="post">
<input class="savebtn" type="submit" value="Save" th:formaction="'/save-post/'+${post.id}">
<input class="publish" type="submit" value="Publish Article">
</form>

对于多个提交按钮,下面的方法对我很有效。* 注意:th:取消按钮中的格式操作。*

<form action="#" th:action="@{/saveProducts}" th:object="${model}" method="post">
  <button type="submit" name="action" value="cancel" th:formaction="@{/cancelProducts}">CANCEL</button>
  <button type="submit" name="action" value="save">SAVE</button>
</form>

对于控制器:

@RequestMapping(value="/saveProducts", method= RequestMethod.POST)
    public String save(@ModelAttribute SomeModel model) {
      *//Do something*
    }
    @RequestMapping(value="/cancelProducts", method=RequestMethod.POST)
    public String cancel(@ModelAttribute SomeModel model) {
      *//Do something*
    }

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-28 08:00:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-28 08:00:04       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-28 08:00:04       82 阅读
  4. Python语言-面向对象

    2024-03-28 08:00:04       91 阅读

热门阅读

  1. Kafka高级面试题-2024

    2024-03-28 08:00:04       43 阅读
  2. 什么是高阶组件,有哪些场景?

    2024-03-28 08:00:04       46 阅读
  3. PHP中常见的CRUD函数

    2024-03-28 08:00:04       43 阅读
  4. 配置服务器时间同步

    2024-03-28 08:00:04       41 阅读
  5. 正则表达式篇

    2024-03-28 08:00:04       42 阅读
  6. Mac 如何安装git

    2024-03-28 08:00:04       38 阅读
  7. 数据结构奇妙旅程之深入解析快速排序

    2024-03-28 08:00:04       42 阅读
  8. 排序算法介绍

    2024-03-28 08:00:04       41 阅读