需要通过`TemplateEngine`对象来将模板文件渲染为最终的HTML页面,且此对象只需要创建一次,之后就可以一直使用了
- TemplateEngine engine;
- @Override
- public void init() throws ServletException {
- engine = new TemplateEngine();
- //设定模板解析器决定了从哪里获取模板文件,这里直接使用ClassLoaderTemplateResolver表示加载内部资源文件
- ClassLoaderTemplateResolver r = new ClassLoaderTemplateResolver();
- engine.setTemplateResolver(r);
- }
使用模板引擎进行解析
- protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
- //创建上下文,上下文中包含了所有需要替换到模板中的内容
- Context context = new Context();
- context.setVariable("title", "我是标题");
- //通过此方法就可以直接解析模板并返回响应
- engine.process("test.html", context, resp.getWriter());
- }
使用`th:text`来为当前标签指定内部文本,注意任何内容都会变成普通文本
如果希望向内部添加一个HTML文本可以使用`th:utext`属性
传入的title属性,不仅仅只是一个字符串的值,而是一个字符串的引用,我们可以直接通过此引用调用相关的方法
`th:`能够拼接几乎所有的属性,一旦使用`th:属性名称`,那么属性的值就可以通过后端提供了
比如
- protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
- Context context = new Context();
- context.setVariable("url", "http://n.sinaimg.cn/sinakd20121/600/w1920h1080/20210727/a700-adf8480ff24057e04527bdfea789e788.jpg");
- context.setVariable("alt", "图片就是加载不出来啊");
- engine.process("test.html", context, resp.getWriter());
- }
- html>
- <html lang="en" xmlns:th="http://www.thymeleaf.org">
- <head>
- <meta charset="UTF-8">
- <title>Titletitle>
- head>
- <body>
- <img width="700" th:src="${url}" th:alt="${alt}">
- body>
- html>
Thymeleaf还可以进行一些算术运算和字符串拼接