FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不只能够用做表现层的实现技术,并且还能够用于生成XML,JSP或Java 等。html
目前企业中主要用Freemarker作静态页面或是页面展现java
首先,添加依赖web
<!-- https://mvnrepository.com/artifact/org.freemarker/freemarker --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.23</version> </dependency>
使用步骤:spring
首先须要建立一个模板文件:app
模板内容:
webapp
若是以前没有在Eclipse中安装过相应的插件,会有弹窗提示安装插件,不过说实话,并无什么用,很不智能......测试
而后先进行简单测试:编码
@Test public void testFreeMarker() throws Exception { // 建立一个模板文件 // 建立一个Configuration对象 Configuration configuration = new Configuration(Configuration.getVersion()); // 设置模板文件保存的目录 configuration.setDirectoryForTemplateLoading(new File("D:/WorkSpace/workspace/e3-item-web/src/main/webapp/WEB-INF/ftl/")); // 设置文件的编码格式,通常是utf-8 configuration.setDefaultEncoding("utf-8"); // 加载一个模板文件,建立一个模板对象 Template template = configuration.getTemplate("hello.ftl"); // 建立一个穆数据集,能够是pojo也能够是map,推荐使用map Map<String, String> data = new HashMap<>(); data.put("hello", "hello freemarker!"); // 建立一个Writer对象,指定输出文件的路径以及文件名 Writer out = new FileWriter(new File("E:/Temp/freemarker/hello.txt")); // 生成静态页面 template.process(data, out); // 关闭流 out.close(); }
执行以后,生成静态文件:spa
1.访问map中的key插件
这个很简单,和EL表达式差很少,就好比上面的${hello }
2.访问pojo中的属性
这个用法也是和EL表达式同样
模板:
运行效果:
3.取集合中的数据
用法:
<#list stuList as student>
学号:${student.id}
</#list>
须要两个参数,分别对应着<c:foreach>标签中的items和var
模板: 执行效果:
4.取循环中的下标
方法:
<#list stuList as student>
学号:${student.id},序号${student_index}
</#list>
效果:
5.判断
用法:
<#if stu_index % 2 == 0>
yyyyyy
<#else>
nnnnnn
</#if>
效果:
6.日期类型格式化
用法:
7.Null值的处理
对于Null值(不存在或为NULL),不进行处理在生成静态文件时就会报错。
两种处理方式:
8.include标签
方法:<#include “模板名称”>
须要注意的是,若是包含的模板中有须要数据的地方,也要将对应的数据放入数据集中。
9.格式化数值
对于数值,好比long型的数据,默认的格式是xx,xxx,xxx若是想将逗号分隔符去掉,须要在后面加一个?c 例:
<!-- Freemaker --> <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/ftl/" /> <property name="defaultEncoding" value="UTF-8" /> </bean>
<strong class="price">${item.price?c }</strong>
这里只是介绍了几种经常使用的语法,具体的语法有不少,能够参看FreeMarker的官方文档。
第一步:引入依赖,整合spring须要的Jar和FreeMarker的Jar:
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> </dependency> <!-- freemarker --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> </dependency>
第二步:建立整合Spring的配置文件
<!-- Freemaker --> <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/ftl/" /><!-- 指定模板文件目录 --> <property name="defaultEncoding" value="UTF-8" /> </bean>
第三步:使用
@Controller public class HtmlGenController { @Autowired private FreeMarkerConfigurer freeMarkerConfigurer; //这里省略了后缀.html,因此访问的时候应该是127.0.0.1:8086/genhtml.html @RequestMapping("/genhtml") @ResponseBody public String genHtml() throws Exception { Configuration configuration = freeMarkerConfigurer.getConfiguration(); // 加载模板对象 Template template = configuration.getTemplate("student.ftl"); // 建立一个数据集 Map<String, Object> data = new HashMap<>(); // 向数据集中添加须要的全部数据,此处省略................................. // 指定文件输出路径以及文件名 Writer out = new FileWriter(new File("E:/Temp/freemarker/student.html")); // 输出文件 template.process(data, out); // 关闭流 out.close(); return "OK"; }}而后启动服务,访问127.0.0.1:8086/genhtml.html,就会生成对应的静态文件student.html
访问: