springMVC整合thymeleaf

springMVC 整合thymeleaf

  1. 添加依赖



    org.thymeleaf
    thymeleaf
    3.0.6.RELEASE



    org.thymeleaf
    thymeleaf-spring4
    3.0.6.RELEASE

  2. 配置文件









    class="org.thymeleaf.spring4.SpringTemplateEngine">







  3. 网页申明


    xmlns:th="http://www.thymeleaf.org">

  4. 表达式符号

    1. "#"代表获取对象从 messages bundle 也就是消息资源本地化文件

      • 在${}中使用时,代表引用方法

      • 2012-12-10

    2. $ 表示从model里面获取

      • #、$这2个可以一起用 比如#{'system.'+${model.id}} 这相当于 #{system.01}的资源本地化文件中的system.01内容

      • 表示从当前对象中读取属性


        Name: Sebastian.


        Surname: Pepper.


        Nationality: Saturn.


    3. @{} 表示一个URL表达式

    4. ~{...} 表示引有页面的表达式

  5. 常用th标签

    • th:each="user: {users}" th:class="{status.index}+1">1

    • th:href 重新生成url th:href="@{/list/details(id={lid}|" 生成:http://domain.org/list/details?id=1 扩展 th:href="@{'/list/details/'+${user.id}} 生成 http://domain.org/context/list/details/1

    • th:text="{user.name}"

    • th:with,定义变量 th:with="isEven=${prodStat.count}%2==0",定义多个变量可以用逗号分隔

    • th:attr,设置标签属性 多个属性可以用逗号分隔,比如th:attr="src=@{/image/aa.jpg},title=#{logo}"

    • th:if or th:unless,条件判断 支持布尔值,数字(非零为true),字符,字符串等

    • th:switch,th:case,选择语句

      • th:case="*"表示default case

      • 示例


      • User is an administrator


        User is a manager


        User is some other thing


      th:fragment,th:include,th:substituteby:fragment为片段标记 指定一个模板内一部分代码为一个片段,然后在其它的页面中用th:include或

      th:substituteby进行包含。 片段格式 "templatename::fragname",指定模板内的指定片段 "templateName::[domselector]",指定模板的dom selector,被包含的模板内不需要th:fragment. ”templatename",包含整个模板 示例 th:include="footer::$(user.logined)?'logined':'notLogin'" 格式内可以为表达式 th:include和th:substituteby的区别 th:include 包含片段的内容到当前标签内 th:substituteby 用整个片段(内容和上一层)替换当前标签(不仅仅是标签内容) th:object 获取model中的对象

      th:field 获取表单中绑定对象的字段
      th:errors 显示页面中包含的错误* 显示username字段上的错误* 显示所有错误 其它请参考:thymeleaf所有标签属性.xlsx和thymeleaf-spring.pdf

你可能感兴趣的:(springMVC整合thymeleaf)