thymeleaf和freemarker比较

  • Post author:
  • Post category:其他


个人更倾向于freemarker这种模板引擎,两者的设计思路本就不同。

我已经习惯了类似于freemarker这种编程式模板引擎,比如之前我们用一个判断会这么写

<#if ${isBig}>Wow!</#if>

而在thymeleaf中你首先要考虑的问题是我的DOM是什么,而不是将

if

的逻辑放在哪里

在thymeleaf中判断会写出下面代码:

<div th:switch="${user.role}"> 
  <p th:case="'admin'">User is an administrator</p>
  <p th:case="#{roles.manager}">User is a manager</p>
  <p th:case="*">User is some other thing</p> 
</div>


thymeleaf优点:

  1. 静态html嵌入标签属性,浏览器可以直接打开模板文件,便于前后端联调。
  2. springboot官方推荐方案。


thymeleaf缺点:

  1. 模板必须符合xml规范,就这一点就可以判死刑!太不方便了!js脚本必须加入/*<![CDATA[*/标识,否则一个&符号就会导致后台模板合成抛异常,而且错误信息巨不友好,害得我调试了好几个小时才明白是怎么回事。js里面还好办,这样是在html里面含有&等符号,还需要转义?忒麻烦了!
  2. 就上面一条就够了。


freemarker优点:


上图描述来自

FreeMarker首页、文档和下载 – Java模板引擎 – 开源中国社区


freemarker缺点:

还真不知道

作者:王爵nice

链接:https://www.zhihu.com/question/64039553/answer/215942472

来源:知乎