JavaWeb页面静态化之使用freemarker模板生成一个html静态页面

时间:2025-01-17 12:34:26

题外话:
       页面静态化(展示数据从JSP页面变成HTML页面)实现方式-->模板技术   从本质上来讲,模板技术是一个占位符动态替换技术。一个完整的模板技术需要四个元素:①模板语言(使用的语法)   ②包含模板语言的模板文件(.ftl结尾)   ③模板引擎(jar包)  ④拥有动态数据的数据对象
       FreeMarker是一款模板引擎:即一种基于模板和要改变的数据,并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。


静态页面在什么时候生成??
    数据新增,修改的时候会生成一个新的静态化页面, 在数据删除的时候会将原有的静态化页面删除

如何使用freemarker模板生成一个html页面呢???
    注意:导入freemarker的jar包JavaWeb页面静态化之使用freemarker模板生成一个html静态页面

点击下载FreeMarker文档+jar包资源   密码:2ndt

  1. /**
  2. * 1.创建配置实例
  3. * 2.获得模板
  4. * 3.创建数据模型[数据模型可以是List、Map对象 注意:Map类型的key必须是String类型]
  5. * 4.将模板和数据模型合并
  6. * @author 郑清
  7. */
  8. public class FreeMarkerTest {
  9. @Test
  10. public void testCreateHtml() throws Exception{
  11. //①创建配置对象
  12. Configuration cfg = new Configuration(Configuration.VERSION_2_3_28);//注意:这里需要传递一个版本
  13. File f = new File("E:/eclipse-workspace/JavaWeb_workspace/JavaWeb/src/main/webapp/test");
  14. //②读取模板文件夹
  15. cfg.setDirectoryForTemplateLoading(f);//设置要加载的模板文件的路径
  16. //③设置模板的编码格式
  17. cfg.setDefaultEncoding("UTF-8");
  18. //④获取模板对象
  19. Template template = cfg.getTemplate("hello.ftl");//hello.ftl是模板名称
  20. //⑤创建数据模型(这里使用map类型) --[数据模型可以是List、Map对象 注意:Map类型的key必须是String类型]
  21. HashMap<String, Object> map = new HashMap<>();
  22. map.put("username", "郑清");
  23. HashMap<String, Object> map2 = new HashMap<>();//map2存储的是a标签的href和显示名字
  24. map2.put("href","https://www.baidu.com");
  25. map2.put("name","百度");
  26. map.put("a", map2);
  27. //⑥将模板和数据模型合并 --> 输出模板,生成文件
  28. PrintWriter pw = new PrintWriter(new File(f, "hello.html"));
  29. template.process(map, pw);//合并 map:数据模型 pw:输出流对象
  30. pw.close();//关闭流
  31. }
  32. }

${key  }     -->   获取数据模型中的对应值

JavaWeb页面静态化之使用freemarker模板生成一个html静态页面

当数据模型为对象时:

JavaWeb页面静态化之使用freemarker模板生成一个html静态页面

浏览器运行效果:

JavaWeb页面静态化之使用freemarker模板生成一个html静态页面


FreeMarker中的基本语法:     (更多语法在FreeMarker文档中查看!!)
①判断:

  1. <#if 条件></#if>
  2. </#esleif 条件>

②遍历:

  1. <#list 数据 as 变量>
  2. ${变量 }
  3. </#list>

③遍历map:  map?keys --> 获取map中的key

  1. <#list map?keys as 变量>
  2. 输出key:${变量}
  3. 输出map的值:${map[变量]}
  4. </#list>