Spring - Spring Boot - Thymeleaf - textual 模式
概述
- thymeleaf 的 text 模式简单使用
- 过程会比较啰嗦, 需要结论的同学, 可以直接到底部去寻找
背景
想尝试做一个简单的 模板工具
目的
- 自动生成一些简单的 重复文本
思路
- 尽量简单
- 使用 json 装填数据
- 这个可能会调整
- 用 restful 方式, 提交给 server
- spring-boot 集成, 很方便
- json 解析
- jackson 看了看, 还行
- 使用 模板 生成内容
- thymeleaf 应该能满足要求
- spring-boot 集成很方便
- 返回 模板生成内容
- 这个 第4步 顺手就做了
- 使用 json 装填数据
- 尽量简单
不过我比较生疏
- jackson 基本没用过
- 不过还算顺利
- thymeleaf 之前也是基本没用过
- 只会传最简单的 静态参数
- 本人前端苦手, 看见 html, js, css 就头晕
- jackson 基本没用过
环境
os
- win10
ide
- idea 2018.1
依赖
- jdk
- 1.8
- spring-boot
- 2.2.2
- maven
- 3.6
- jdk
1. 准备
spring-boot 创建 maven 工程
- 略
spring-boot 创建 restful 服务
- 略
thymeleaf 模板与传参
- 知道传到 那个模板
- 知道参数写在哪, 怎么取
2. 尝试1: 使用 thymeleaf 的 text 模式尝试
controller
model
添加属性
model.addAttribute("var1", "value1");
view
视图
return "test";
test.html
[(${var1})]
结果
- 成功展示
3. 尝试2: 尝试循环
controller
List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
model.addAttribute("list", list);
test.html
[# th:each="item : ${list}"]
- [(${item})]
[/]
结果
- 失败
- 直接原文显示
- 失败
疑问: 为啥会失败了呢?
- 问题
- 代码基本是 官网复制过来的
- 之前也没啥问题, 怎么会失败呢?
- 问题
4. 尝试3: 在 test.html 添加 尝试1 里的代码
结果
- var1 成功展示
- 后面的 循环, 还是没有成功
疑问: 为啥会是这种呢
- 感觉像是 循环的语法, 没有被 正确识别的样子
- 语法识别, 是跟 模式 相关吗?
5. 尝试4: 设置模式
发现
thymeleaf 可以定义 html5 严格模式
spring.thymeleaf.mode=LEGACYHTML5
其他的模式, 也是可以设置的
- ref2
配置文件 application.properties
添加内容
spring.thymeleaf.mode=TEXT
结果
- 还是不行
疑问
- 忽然发现, 官网的例子, 举的都是 邮件, js, css
- 我用的是 html, 会不会跟这个有关
- 忽然发现, 官网的例子, 举的都是 邮件, js, css
6. 尝试5; 换 模板文件
疑问
- thymeleaf 默认会给 模板名称结尾, 加上一个 .html
处理
去掉 .html 的默认后缀
application.properties
spring.thymeleaf.suffix=
重命名 模板
- 改名为 "test"
重启服务器
尝试
- ok
后续
尝试1: 去掉 模式定义 的语句
- 又不能解析了
尝试2: 将 模板名称, 改回 "test.html"
- 还是不行
7. 结论
想要使用 text 模式, 需要做以下操作
application.properties
spring.thymeleaf.mode=TEXT
spring.thymeleaf.suffix=
模板
- 使用 text 模式的专用语法
如果其他地方, 想用 html
- 在 controller 方法的 返回值里, 使用 x.html 类似的视图名称
过程, 感觉有点曲折
- 之前没怎么接触
- 真的想不到, 这个工作模式, 还会跟 模板的后缀名 做一个挂钩
- 而且还有一个开关
- 感觉这种盲猜真的很麻烦
- 照着官网抄都超不对, 体验真实差到了极点, 很容易收到打击...
- 不知道经验老到的同学, 在这块会不会遇到这种新手问题...前前后后, 花了个把小时, 感觉浪费很多时间的样子...
- 或者换个角度, thymeleaf 的开发者, 就不想在这种场景, 让用户使用 text 模式
- 这个角度也是收到了留言小伙伴的启发...
8. 猜测
text 模式语法
- 语法本身, 是 inline 模式
- html 支持部分 inline 模式的语法
- 支持变量提取
- 不支持 each
模板解析
- 根据 模板的后缀, 选择合适的 解析器
- 每种解析器, 只能解析 有限的语法
- 解析 html 的解析器, 无法解析 text 模式的 each
ps
ref
-
- 官网 文档
- 本身比较详细, 但是 textual 模式, 却说得比较略
- 官网 文档
Thymeleaf 3 ten-minute migration guide
- 官网 文档
- 讲了些 spring 的代码配置
- 可惜版本是 spring4 的
- 我用的是 spring5, 可能会有点出入
- 大体结构是这样
- viewResolver: 视图解析器
- templateEngine: 模板引擎
- templateResolver: 模板解析器
- templateEngine: 模板引擎
- viewResolver: 视图解析器
- 但是后面具体的调用机制, 我就不太熟悉了
- 讲了些 spring 的代码配置
- 官网 文档
thymeleaf3-template-modes-example
- 官网 例子
大概给了三套
- 视图解析器, 模板引擎, 模板解析器
具体什么机制, 也没说明白
- 或者说, 我没看明白
- 比如说
- 这些 解析器, 什么时候调用哪个?
- 盲猜
- 根据 controller 视图的后缀, 来确定使用哪个 模板解析器
- 具体机制, 还没深入了解
- 官网 例子
-
怎么说呢?
- 还是喜欢那种, 先学习, 后使用 的工作模式
- 这种 边用边查资料 的模式, 我不太喜欢
- 做东西太赶
- 做了前面, 容易给后面埋坑
- 学东西太着急
- 容易造成理解问题
- 做东西太赶
- 不过这种方式, 应该是大多数公司的日常工作模式吧
- 反正我接触的, 基本是这样...
- 想想还有点难受
- 这种 边用边查资料 的模式, 我不太喜欢
- 还是喜欢那种, 先学习, 后使用 的工作模式
如果用 其他模板引擎 做同样的事, 会有这么麻烦吗?
- jsp
- Velocity
- freemarker
Spring - Spring Boot - Thymeleaf - textual 模式的更多相关文章
- spring boot + thymeleaf 3 国际化
在给spring boot 1.5.6 + thymeleaf 3进行国际化时,踩了一个坑(其实不止一个). 现象: 看到了吧, 就是取值的key, 后面被加了_en_US 或 _zh_CN, 以及前 ...
- spring boot + Thymeleaf开发web项目
"Spring boot非常适合Web应用程序开发.您可以轻松创建自包含的HTTP应用.web服务器采用嵌入式Tomcat,或者Jetty等.大多数情况下Web应用程序将使用 spring- ...
- Spring boot+Thymeleaf+easyui集成:js创建组件页面报错
开发工具:Ideal 使用场景:Demo 前提: 环境:Spring boot +Thymeleaf+easyui 引入thymeleaf模板引擎 <html lang=" ...
- Intellij IDEA Spring Boot 项目Debug模式启动缓慢问题
问题 Intellij IDEA Spring Boot 项目Debug模式启动缓慢 环境 os: windows10 idea :2018.1 解决方法 去除所有断点就正常了,很诡异,原因未知.
- spring boot: thymeleaf模板引擎使用
spring boot: thymeleaf模板引擎使用 在pom.xml加入thymeleaf模板依赖 <!-- 添加thymeleaf的依赖 --> <dependency> ...
- Spring Boot Thymeleaf 实现国际化
开发传统Java WEB工程时,我们可以使用JSP页面模板语言,但是在SpringBoot中已经不推荐使用了.SpringBoot支持如下页面模板语言 Thymeleaf FreeMarker Vel ...
- Spring Boot 2.X(三):使用 Spring MVC + MyBatis + Thymeleaf 开发 web 应用
前言 Spring MVC 是构建在 Servlet API 上的原生框架,并从一开始就包含在 Spring 框架中.本文主要通过简述 Spring MVC 的架构及分析,并用 Spring Boot ...
- spring boot + thymeleaf 乱码问题
spring boot + thymeleaf 乱码问题 hellotrms 发布于 2017/01/17 15:27 阅读 1K+ 收藏 0 答案 1 开发四年只会写业务代码,分布式高并发都不会还做 ...
- Spring boot +Thymeleaf 搭建springweb
对接天猫精灵的时候需要有网关服务器方提供几个页面,服务器已经有了,spring boot的 纯后台的,就加了Thymeleaf jar包添加几个页面跳转 maven配置 <!-- 引入thy ...
随机推荐
- .net core 3.0 swagger
1.安装swagger包 2.startup里configservers Configure 3.可能出现的错误 提示error xxxxnot found 由于我创建的webapi是restful ...
- ihandy2019笔记编程真题
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- float浮动以及案例演示
浮动元素会影响后边的元素,但不会影响前边的元素 清除浮动: 方法一:在浮动元素后面添加一个空元素 <!DOCTYPE html> <html lang="en"& ...
- 剑指offer-面试题56_1-数组中只出现一次的两个数字-位运算
/* 题目: 求数组A中只出现一次的数字,该数组中有2个数字a.b仅出现一次,其余均出现两次 */ /* 思路: 两个相同的数字异或为0. 遍历数组,得到数组中各数字异或后的结果x,结果x=a^b. ...
- Maximum Element In A Stack Gym - 102222A【思维+栈】
2018-2019 ACM-ICPC, China Multi-Provincial Collegiate Programming Contest https://vjudge.net/problem ...
- 复习mongoose的基本使用
mongodb参考 mongoose官网 mongoose用起来更便捷,更方便些
- jQuery笔记(六)jQuery之Ajax
jQuery确实是一个挺好的轻量级的JS框架,能帮助我们快速的开发JS应用,并在一定程度上改变了我们写JavaScript代码的习惯. 废话少说,直接进入正题,我们先来看一些简单的方法,这些方法都是对 ...
- vue动画&过渡整理
- 关于Comparable和Comparator那些事
在实际项目开发过程中,我们经常需要对某个对象或者某个集合中的元素进行排序,常用的两种方式是实现某个接口.常见的可以实现比较功能的接口有Comparable接口和 Comparator接口,那么这两个又 ...
- C++使用taskkill 命令强制结束进程
一:查看 taskkill 命令和参数的方法 window系统下,快捷键win + R 打开运行 ,输入cmd回车,在 cmd 里面输入: taskkill /? 二:语法: taskkill [/ ...