data:image/s3,"s3://crabby-images/f8b53/f8b53a299af198f3380b4640df588a26db820b91" alt="名师讲坛:Java微服务架构实战(SpringBoot+SpringCloud+Docker+RabbitMQ)"
3.2 Thymeleaf编程起步
Thymeleaf需要按照传统MVC设计模式的方式来进行处理,所以在定义控制器的时候必须使用@Controller注解来完成。通过控制器的Model类对象,可以传递相应属性到页面中显示。
1.【mldnboot-thymeleaf项目】建立ThymeleafController程序类,该类将跳转到Thyemelaf模板页面。
data:image/s3,"s3://crabby-images/ac1a4/ac1a4aba62b34f2d46e9f70d1a516ff3bc12eb5d" alt=""
2.【mldnboot-thymeleaf项目】ThymeleafController控制器会跳转到message目录下的message_show.html页面进行显示,而该页面一定要在CLASSPATH路径下配置。为了结构清晰,本程序将建立一个src/main/view的源文件,并且必须建立templates目录,随后在这个目录下创建所需要的子目录(本程序需要创建message子目录)。项目最终的目录结构如图3-1所示。
data:image/s3,"s3://crabby-images/df286/df2863d90e22d163e6d184e6d6565dcba86f7062" alt=""
图3-1 Thymeleaf模板目录结构
提示:修改Thymeleaf的默认配置。
SpringBoot项目中Thymeleaf的动态页面需要保存在templates目录中,页面的扩展名默认使用的是*.html,如果开发者觉得这样的设计不合理,也可以通过application.yml配置文件自行修改。
范例:修改Thyemeleaf的配置项。
data:image/s3,"s3://crabby-images/268e3/268e356df09ece713954a02d438d918c5312413a" alt=""
虽然SpringBoot中可以修改Thymeleaf的默认配置项,但是在实际开发中不建议修改,还是遵从默认配置比较合理。
3.【mldnboot-thymeleaf项目】编写message_show.html页面,实现控制层传递属性输出。
data:image/s3,"s3://crabby-images/d4ef4/d4ef4953e596181ad82d75909311859e69a48e8d" alt=""
本程序使用<p>元素设定了要输出的内容。要想使用Thymeleaf的功能,必须以“th:属性”的形式处理,th:text的主要作用是进行文本输出。而要想输出request属性中的内容,则需要采用“${属性名称}”的语法格式完成。随后启动程序,输入访问地址http://localhost/view?mid=mldnjava,页面运行效果如图3-2所示。
data:image/s3,"s3://crabby-images/54e3c/54e3c3d8504be19fd1505c9065c2fdb0653fe2cb" alt=""
图3-2 Thymeleaf模板运行
提示:传递HTML元素信息。
在本程序中,如果控制器传递的是一个HTML元素,那么对于Thymeleaf页面而言,就需要使用th:utext来显示HTML元素内容。
范例:【mldnboot-thymeleaf项目】修改ThymeleafController控制器,传递HTML元素。
data:image/s3,"s3://crabby-images/9a8ff/9a8ff2d74738f662f5ddd2bec31d1791da13c950" alt=""
范例:【mldnboot-thymeleaf项目】修改message_show.html页面。
data:image/s3,"s3://crabby-images/5960a/5960a4a33c3e0e68cd1d99a3251f3df589478413" alt=""
本程序为了说明问题,特意使用了th:text和th:utext来输出url属性内容,程序执行结果如图3-3所示。
data:image/s3,"s3://crabby-images/a6369/a63694c385293b8513aeeaf7196821ffd7167adc" alt=""
图3-3 传递HTML元素
另外需要注意的是,在Thymeleaf语法里面也可以直接使用各种运算符。
data:image/s3,"s3://crabby-images/8dcb1/8dcb122882005026274688345656b50cb6d941e8" alt=""
此时,Thyemeleaf模板页面会自动根据运算的数据类型和运算符进行计算。