thymeleaf处理参数传递问题

Thymeleaf 处理参数传递主要涉及页面跳转传参表单提交传参URL 拼接传参 等场景,结合效果图和 Postman 测试能更直观理解参数传递与接收流程。以下分场景详细说明:

一、URL 拼接传参(GET 请求)

1. 页面跳转时拼接参数

Thymeleaf 页面代码

html 复制代码
<!-- 拼接参数:name=张三&age=20 -->
<a th:href="@{/user/detail(name='张三', age=20)}">查看用户详情</a>

效果图

页面显示超链接,点击后 URL 为:http://localhost:8080/user/detail?name=张三&age=20

2. 后端接收参数(Spring Boot 示例)
java 复制代码
@GetMapping("/user/detail")
public String userDetail(@RequestParam String name, @RequestParam Integer age, Model model) {
    model.addAttribute("name", name);
    model.addAttribute("age", age);
    return "userDetail"; // 跳转到userDetail.html
}
3. Postman 测试 GET 请求
  • 请求地址http://localhost:8080/user/detail
  • 请求参数 :Params 中添加 name=张三age=20
  • 响应:返回渲染后的页面,显示参数值。

二、表单提交传参(POST 请求)

1. Thymeleaf 表单代码
html 复制代码
<form th:action="@{/user/save}" method="post">
    <input type="text" name="username" placeholder="用户名">
    <input type="password" name="password" placeholder="密码">
    <button type="submit">提交</button>
</form>

效果图

页面显示表单输入框,提交后参数通过 POST 请求传递。

2. 后端接收参数
java 复制代码
@PostMapping("/user/save")
public String saveUser(User user, Model model) {
    model.addAttribute("user", user);
    return "userResult"; // 显示提交结果
}

// User实体类
public class User {
    private String username;
    private String password;
    // getter/setter
}
3. Postman 测试 POST 请求
  • 请求地址http://localhost:8080/user/save
  • 请求体 :form-data 中添加 username=testpassword=123456
  • 响应:返回包含用户信息的页面。

三、页面渲染参数(后端→前端)

1. 后端传递参数到 Model
java 复制代码
@GetMapping("/index")
public String index(Model model) {
    model.addAttribute("message", "Hello Thymeleaf!");
    model.addAttribute("user", new User("李四", "654321"));
    return "index";
}
2. Thymeleaf 页面接收并渲染
html 复制代码
<h1 th:text="${message}">默认消息</h1>
<p>用户名:<span th:text="${user.username}"></span></p>
<p>密码:<span th:text="${user.password}"></span></p>

效果图

页面显示:

复制代码
Hello Thymeleaf!
用户名:李四
密码:654321

四、复杂参数传递(对象/集合)

1. 传递集合参数
java 复制代码
@GetMapping("/list")
public String userList(Model model) {
    List<User> userList = Arrays.asList(
        new User("张三", "123"),
        new User("李四", "456")
    );
    model.addAttribute("users", userList);
    return "userList";
}
2. Thymeleaf 遍历集合
html 复制代码
<table>
    <tr th:each="user : ${users}">
        <td th:text="${user.username}"></td>
        <td th:text="${user.password}"></td>
    </tr>
</table>

效果图

表格显示两行用户数据。

五、Postman 测试注意事项

  1. GET 请求:参数放在 Params 或直接拼接在 URL。
  2. POST 请求:表单参数用 form-data,JSON 参数用 raw → JSON。
  3. 响应类型 :若返回页面,Postman 显示 HTML;若返回 JSON,需用 @ResponseBody

总结

Thymeleaf 通过 @{} 处理 URL 参数,${} 渲染后端数据;结合 Postman 可快速验证参数传递是否正确,重点关注请求方式、参数格式和后端接收逻辑。

相关推荐
秋月的私语5 分钟前
遥感影像拼接线优化工具:基于Qt+GDAL+OpenCV的从零到一实践
开发语言·qt·opencv
xwz小王子13 分钟前
智元发布 GO-2:动作空间推理 + 全生命周期闭环,让机器人稳定可靠落地
开发语言·golang·机器人
charlie11451419113 分钟前
通用GUI编程技术——图形渲染实战(二十八)——图像格式与编解码:PNG/JPEG全掌握
开发语言·c++·windows·学习·图形渲染·win32
ZC跨境爬虫16 分钟前
海南大学交友平台登录页开发实战day4(解决python传输并读取登录信息的问题)
开发语言·前端·python·flask·html
wjs202419 分钟前
SQL LEN() 函数详解
开发语言
姓刘的哦24 分钟前
Qt自定义控件
开发语言·qt
Ricky_Theseus25 分钟前
C++静态库
开发语言·c++
SuperEugene25 分钟前
Python 异步 async/await:为什么 AI 框架大量使用?| 基础篇
开发语言·人工智能·python
SMF191931 分钟前
【uv】Python包管理器uv安装和应用
开发语言·python·uv
Lyyaoo.32 分钟前
【JAVA基础面经】String、StringBuffer、StringBuilder
java·开发语言