thymeleaf的使用和小结

thymeleafJavaScript在前后端交互中获取后端值

在JavaScript中,可以通过Thymeleaf的属性绑定来获取后端的值。Thymeleaf会将后端传递的数据绑定到HTML模板中的特定属性上,然后你可以使用JavaScript来读取这些属性的值。案例演示如下:

  • 在后端(Java)中,将数据传递给前端:
java 复制代码
model.addAttribute("message", "Hello, Thymeleaf!");
  1. 方式1:
    通过将数据绑定到HTML元素的特定属性上,然后使用JavaScript获取该元素,并读取其属性值。在这个例子中,我们将数据绑定到div元素的text属性上,然后使用getElementById方法获取该元素并读取其textContent。
  • 在HTML模板中,使用Thymeleaf属性绑定将数据绑定到HTML元素上:
java 复制代码
<div th:text="${message}" id="message"></div>
  • 在JavaScript中,使用getElementById或querySelector等方法获取绑定了数据的HTML元素,并读取其值
java 复制代码
* javascript
var messageElement = document.getElementById("message");
var message = messageElement.textContent;
console.log(message);  // 输出:Hello, Thymeleaf!
  1. 方式2
    在内联的JavaScript代码中直接使用Thymeleaf表达式获取后端的值。在这个例子中,我们使用Thymeleaf的th:inline属性将JavaScript代码标记为内联模式,并使用[[${message}]]来获取后端传递的值。
java 复制代码
<script th:inline="javascript">
	var message = [[${message}]];
	console.log(message);  // 输出:Hello, Thymeleaf!
</script>

hymeleaf中前后端数据交互小结

  1. 引入静态资源:th:href或th:scr+@{/从static目录开始}
java 复制代码
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <link th:href="@{/iamges/favicon.ico}" type="image/x-icon"/>
    <link th:href="@{/css/bootstrap.min.css}" rel="stylesheet"/>
    <meta charset="UTF-8">
    <title>书籍管理</title>
</head>
  1. 前端将数据绑定到后端对象:*{对象属性},前端引用后端数据${对象属性}
java 复制代码
<div class="form-group">
    <label for="book_name" class="col-sm-2 control-label">书名:</label>
    <div class="col-xs-4">
        <input type="text" class="form-control" id="book_name" 
               name="name" th:value="${book.name}" th:field="*{book.name}"/>
    </div>
</div>

3.后端将数据传入前端 ModelMap(由框架提供),前端使用${对象属性}

java 复制代码
@RequestMapping(value = "/create",method = RequestMethod.GET)
public String createBookForm(ModelMap map){
    map.addAttribute("book",book);
    map.addAttribute("action","create");
    return BOOK_FORM;
}

4.表单提交的注意点。

  1. action:表单中的内容提交给哪个页面进行处理,可能的取值:URL

  2. input元素: 输入框,由type决定类型。

  3. 触发提交的动作:

HTML DOM submit() 方法。

type=submit

button

相关推荐
eqwaak010 小时前
Flask实战指南:从基础到高阶的完整开发流程
开发语言·后端·python·学习·flask
GilgameshJSS10 小时前
STM32H743-ARM例程9-IWDG看门狗
c语言·arm开发·stm32·单片机·嵌入式硬件·学习
真的想不出名儿11 小时前
vue项目引入字体
前端·javascript·vue.js
胡楚昊11 小时前
Polar WEB(1-20)
前端
吃饺子不吃馅11 小时前
AntV X6图编辑器如何实现切换主题
前端·svg·图形学
月盈缺11 小时前
学习嵌入式的第四十一天——ARM——时钟与定时器
arm开发·学习
努力毕业的小土博^_^12 小时前
【深度学习|学习笔记】详细讲解一下 深度学习训练过程中 为什么 Momentum 可以加速训练?
人工智能·笔记·深度学习·学习·momentum
清风吹过12 小时前
少样本学习论文分享:多模态和类增量学习
论文阅读·人工智能·深度学习·学习·机器学习
Larry_Yanan12 小时前
QML学习笔记(十四)QML的自定义模块
开发语言·笔记·qt·学习·ui
wdfk_prog12 小时前
[Linux]学习笔记系列 -- lib/sort.c 通用的排序库(Generic Sorting Library) 为内核提供标准的、高效的排序功能
linux·运维·c语言·笔记·stm32·学习·bug