Spring Boot 学习笔记 4 : Thymeleaf

  1. 在 pom.xml 文件中添加依赖:

    <dependency>
    	<groupId>org.springframework.boot</groupId>
    	<artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    
  2. 在 application.properties 文件中添加(默认)配置:

    spring.thymeleaf.cache=false
    spring.thymeleaf.encoding=utf-8
    spring.thymeleaf.mode=HTML5
    spring.thymeleaf.prefix=classpath:/templates/
    spring.thymeleaf.suffix=.html
    
  3. 创建 JavaBean:

    public class Person {
    
        private String name;
        private Integer age;
    
        public Person() {
        }
    
        public Person(String name, Integer age) {
            this.name = name;
            this.age = age;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public Integer getAge() {
            return age;
        }
    
        public void setAge(Integer age) {
            this.age = age;
        }
    }
    
  4. 编写 Controller:

    package com.springboot.controller;
    
    import com.springboot.domain.Person;
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.RequestMapping;
    
    import java.util.ArrayList;
    import java.util.List;
    
    @Controller
    @Slf4j
    public class HelloController {
    
        @RequestMapping("/hello")
        public String index(Model model) {
            log.info("收到请求");
            Person person1 = new Person("长相思", 18);
            Person person2 = new Person("花似伊", 19);
            Person person3 = new Person("柳似伊", 20);
    
            List<Person> people = new ArrayList<>();
            people.add(person1);
            people.add(person2);
            people.add(person3);
    
            model.addAttribute("people", people);
    
            return "index";
        }
    }
    
  5. 在 src/main/resources/templates 目录下创建 index.html 文件:

    <!DOCTYPE html>
    <html xml:th = "http://www.thymeleaf.org">
    <head>
        <title>mail</title>
        <meta charset="UTF-8"/>
    </head>
    <body>
        <div data-th-unless="${#lists.isEmpty(people)}">
            <h3>列表</h3>
            <div>
                <ul>
                    <li data-th-each="person:${people}">
                        <span data-th-text="${person.name}"></span>
                        <span data-th-text="${person.age}"></span>
                        <button data-th-"'getName(\''+${person.name}+'\')'">获取名字</button>
                    </li>
                </ul>
            </div>
        </div>
        <script data-th-inline="javascript">
            function getName(name) {
                alert(name);
            }
        </script>
    </body>
    </html>
    
  6. 在 application.properties 文件中添加配置,使用浏览器测试:

    server.port=80
    

    test

  7. 需要注意的地方:

    • 在控制器类中使用的是 @Controller 注解而不是 @RestController 注解,@RestController 注解返回 json 格式,而 thymeleaf 解析的是 html 格式。

    使用restcontroller

    • 在 html 文件中使用 data- 前缀的 th 表达式,以免 IDEA 语法检查时飘红。

    data-

    • 在 html 文件中使用 onclick 属性的 th 表达式调用 js 函数传递参数时,参数如果是表达式,在进行字符串拼接时需要用单引号包裹起来,并且单引号需要使用反斜杠 “\” 进行转义,如以下示例:

    data-th-" 'getName(\'' + ${person.name} + '\')' "
    

    • 在 html 文件中使用 th 表达式时会有作用范围,因此注意正确的嵌套 html 标签,以避免 thymeleaf 解析时出现错误:

    标签需要正确嵌套

    <li> 标签提前关闭后,<span> 标签中的 person 变量失效,person.name 无法获取:

    2018-01-24 13:09:34.661 ERROR 5640 --- [p-nio-80-exec-1] org.thymeleaf.TemplateEngine             :
    [THYMELEAF][http-nio-80-exec-1] Exception processing template "index": Exception evaluating SpringEL expression: "person.name" (index:13)
    
    2018-01-24 13:09:34.668 ERROR 5640 --- [p-nio-80-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    :
    Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed;
    nested exception is org.thymeleaf.exceptions.TemplateProcessingException: Exception evaluating SpringEL expression: "person.name" (index:13)] with root cause
    
    org.springframework.expression.spel.SpelEvaluationException: EL1007E: Property or field 'name' cannot be found on null
    

    EL1007E

    • 如果 html 文件不是严格的 html5 格式,使用如下配置会抛出异常。

    spring.thymeleaf.mode=HTML5
    

    抛出异常:

    [THYMELEAF][http-nio-8080-exec-2] Fatal error during parsing
    	org.xml.sax.SAXParseException: 元素类型 "link" 必须由匹配的结束标记 "</link>" 终止。
    

    可以将配置修改为:

    spring.thymeleaf.mode=LEGACYHTML5
    

    并添加如下依赖即可:

    <dependency>
    	<groupId>net.sourceforge.nekohtml</groupId>
    	<artifactId>nekohtml</artifactId>
    </dependency>
    
  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值