Spring Boot学习(四)之web开发渲染页面 -- Thymeleaf
来源:互联网 发布:json数组格式 编辑:程序博客网 时间:2024/06/05 11:45
我们体验完了一个简单的RESTful api开发服务;
来加载静态资源访问
在我们开发Web应用的时候,需要引用大量的js、css、图片等静态资源。
默认配置
Spring Boot默认提供静态资源目录位置需置于classpath下,目录名需符合如下规则:
- /static
- /public
- /resources
- /META-INF/resources
举例:我们可以在src/main/resources/目录下创建static,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/GG.jpg。如能显示图片,配置成功。
渲染Web页面
在之前的示例中,我们都是通过@RestController来处理请求,所以返回的内容为json对象。那么如果需要渲染html页面的时候,要如何实现呢?
模板引擎
在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。
Spring Boot提供了默认配置的模板引擎主要有以下几种:
- Thymeleaf
- FreeMarker
- Velocity
- Groovy
- Mustache
Spring Boot建议使用这些模板引擎,避免使用JSP,若一定要使用JSP将无法实现Spring Boot的多种特性,具体可见后文:支持JSP的配置
当你使用上述模板引擎中的任何一个,它们默认的模板配置路径为:src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。
Thymeleaf
Thymeleaf是一个XML/XHTML/HTML5模板引擎,可用于Web与非Web环境中的应用开发。它是一个开源的Java库,基于Apache License 2.0许可,由Daniel Fernández创建,该作者还是Java加密库Jasypt的作者。
Thymeleaf提供了一个用于整合Spring MVC的可选模块,在应用开发中,你可以使用Thymeleaf来完全代替JSP或其他模板引擎,如Velocity、FreeMarker等。Thymeleaf的主要目标在于提供一种可被浏览器正确显示的、格式良好的模板创建方式,因此也可以用作静态建模。你可以使用它创建经过验证的XML与HTML模板。相对于编写逻辑或代码,开发者只需将标签属性添加到模板中即可。接下来,这些标签属性就会在DOM(文档对象模型)上执行预先制定好的逻辑。
示例模板:
01
<
table
>
02
<
thead
>
03
<
tr
>
04
<
th
th:text
=
"#{msgs.headers.name}"
>Name</
td
>
05
<
th
th:text
=
"#{msgs.headers.price}"
>Price</
td
>
06
</
tr
>
07
</
thead
>
08
<
tbody
>
09
<
tr
th:each
=
"prod : ${allProducts}"
>
10
<
td
th:text
=
"${prod.name}"
>Oranges</
td
>
11
<
td
th:text
=
"${#numbers.formatDecimal(prod.price,1,2)}"
>0.99</
td
>
12
</
tr
>
13
</
tbody
>
14
</
table
>
可以看到Thymeleaf主要以属性的方式加入到html标签中,浏览器在解析html时,当检查到没有的属性时候会忽略,所以Thymeleaf的模板可以通过浏览器直接打开展现,这样非常有利于前后端的分离。
在Spring Boot中使用Thymeleaf,只需要引入下面依赖,并在默认的模板路径src/main/resources/templates下编写模板文件即可完成。
1
<
dependency
>
2
<
groupId
>org.springframework.boot</
groupId
>
3
<
artifactId
>spring-boot-starter-thymeleaf</
artifactId
>
4
</
dependency
>
在完成配置之后,举一个简单的例子,在快速入门工程的基础上,举一个简单的示例来通过Thymeleaf渲染一个页面。
01
package
com.xiaojingg.web;
02
03
import
org.springframework.stereotype.Controller;
04
import
org.springframework.ui.ModelMap;
05
import
org.springframework.web.bind.annotation.RequestMapping;
06
import
org.springframework.web.bind.annotation.ResponseBody;
07
08
/**
09
*
10
* @author 筱进GG
11
*
12
*/
13
@Controller
14
public
class
HelloController {
15
16
@ResponseBody
17
@RequestMapping
(
"/hello"
)
18
public
String hello() {
19
return
"Hello World"
;
20
}
21
22
@RequestMapping
(
"/"
)
23
public
String index(ModelMap map) {
24
map.addAttribute(
"name"
,
"筱进GG"
);
25
return
"index"
;
26
}
27
28
}
01
<!DOCTYPE html>
02
<
html
>
03
<
head
lang
=
"en"
>
04
<
meta
charset
=
"UTF-8"
/>
05
<
title
></
title
>
06
</
head
>
07
<
body
>
08
<
h1
th:text
=
"${name}"
>Hello World</
h1
>
09
</
body
>
10
</
html
>
如上页面,直接打开html页面展现Hello World,但是启动程序后,访问http://localhost:8080/,则是展示Controller中name的值:筱进GG,做到了不破坏HTML自身内容的数据逻辑分离。
更多Thymeleaf的页面语法,还请访问Thymeleaf的官方文档查询使用。
Thymeleaf的默认参数配置
如有需要修改默认配置的时候,只需复制下面要修改的属性到application.properties中,并修改成需要的值,如修改模板文件的扩展名,修改默认的模板路径等。
01
# Enable template caching.
02
spring.thymeleaf.cache=true
03
# Check that the templates location exists.
04
spring.thymeleaf.check-template-location=true
05
# Content-Type value.
06
spring.thymeleaf.content-type=text/html
07
# Enable MVC Thymeleaf view resolution.
08
spring.thymeleaf.enabled=true
09
# Template encoding.
10
spring.thymeleaf.encoding=UTF-8
11
# Comma-separated list of view names that should be excluded from resolution.
12
spring.thymeleaf.excluded-view-names=
13
# Template mode to be applied to templates. See also StandardTemplateModeHandlers.
14
spring.thymeleaf.mode=HTML5
15
# Prefix that gets prepended to view names when building a URL.
16
spring.thymeleaf.prefix=classpath:/templates/
17
# Suffix that gets appended to view names when building a URL.
18
spring.thymeleaf.suffix=.html spring.thymeleaf.template-resolver-order= # Order of the template resolver in the chain. spring.thymeleaf.view-names= # Comma-separated list of view names that can be resolved.
支持JSP的配置
Spring Boot并不建议使用,但如果一定要使用,可以参考此工程作为脚手架:JSP支持
至此,完成了支持Thymeleaf渲染,欢迎大家一起学习!
欢迎大家一起交流学习SpringBoot,java等领域的技术,交流群 : 587674051 博客的源码也在里面
- Spring Boot学习(四)之web开发渲染页面 -- Thymeleaf
- Spring Boot学习(四)之web开发渲染页面 -- Freemarker
- Spring Boot学习(四)之web开发渲染页面 -- Velocity
- Spring boot 使用Thymeleaf对web视图进行渲染
- Spring Boot基础7-web应用开发-模板引擎Thymeleaf
- SpringBoot16-springboot的Web开发-Spring Boot的Thymeleaf支持
- spring-boot thymeleaf模板学习
- Spring Boot 12之 thymeleaf
- Spring Boot 系列之 thymeleaf
- Spring Boot学习之旅:(十二)模版引擎-Thymeleaf
- spring boot(四):thymeleaf使用详解
- spring boot(四):thymeleaf使用详解
- Spring Boot系列(四):thymeleaf使用详解
- spring boot(四):thymeleaf使用详解
- Spring Boot系列(四):thymeleaf使用详解
- spring boot(四):thymeleaf使用详解
- spring boot(四):thymeleaf使用详解
- 转载:Spring Boot (四):thymeleaf使用详解
- Linux tomcat关闭 出现 java.net.ConnectException: Connection refused
- MFC更改环境目录可执行文件目录下继承的值
- 使用teragen产生数据
- 【Axure 实战】基础操作记录+oa系统表单表格类原型
- fake-useragent,python爬虫伪装请求头
- Spring Boot学习(四)之web开发渲染页面 -- Thymeleaf
- 矩阵外积与内积
- QTP触发了场景恢复,但是没有重复当前步骤并继续
- 2017双十一复盘--开发经验总结
- 关于内部函数与外部函数
- 1004. 成绩排名 (20)
- Java判断密码强度工具类
- Spring Boot学习(四)之web开发渲染页面 -- Freemarker
- 用echarts撸了个Nginx连接数监控