1. 什么是freemarker?
模板 + 数据集 = 填充生成文件或者HTML
1) FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2)模板编写为FreeMarker Template Language (FTL)。它是简单的,专用的语言, 不是 像PHP那样成熟的编程语言。 那就意味着要准备数据在真实编程语言中来显示,比如数据库查询和业务运算, 之后模板显示已经准备好的数据。在模板中,你可以专注于如何展现数据, 而在模板之外可以专注于要展示什么数据。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
3)这种方式通常被称为 MVC (模型 视图 控制器) 模式,对于动态网页来说,是一种特别流行的模式。 它帮助从开发人员(Java 程序员)中分离出网页设计师(HTML设计师)。设计师无需面对模板中的复杂逻辑, 在没有程序员来修改或重新编译代码时,也可以修改页面的样式。
2.在maven中引入坐标
<!-- freemarker jar -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.20</version>
</dependency>
2.1 配置spring配置文件
<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>
3.创建模板文件
<html>
<head>
<title>student</title>
</head>
<body>
${hello}
学生信息:<br/>
学生编号:${student.id}
学生姓名:${student.name}
学生生日:${student.birthday} <br/>
学生列表:
<table border="1">
<tr>
<th>学生编号</th>
<th>学生姓名</th>
<th>学生生日</th>
</tr>
<#list stuList as stu>
<#if stu_index % 2 == 0>
<tr bgcolor="red">
<#else>
<tr bgcolor="green">
</#if>
<td>${stu.id}</td>
<td>${stu.name}</td>
<td>${stu.birthday}</td>
</tr>
</#list>
</table>
当前时间: ${date?date}<br/>
格式化时间: ${date?string('yyyy/MM/dd HH:mm:ss')}
</body>
</html>
4.代码编写步骤(步骤固定)
import java.io.File;
import java.io.FileWriter;
import java.io.Writer;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.junit.Test;
import freemarker.template.Configuration;
import freemarker.template.Template;
public class FreeMarkerTest {
@Test
public void testFreemarker() throws Exception {
// 创建模板配置对象Configuration
Configuration configuration = new Configuration(Configuration.getVersion());
// 设置模板目录
configuration
.setDirectoryForTemplateLoading(new File("E:/workspaces/e3/e3-item-web/src/main/webapp/WEB-INF/ftl"));
// 设置字符集
configuration.setDefaultEncoding("utf-8");
// 获取Template对象
Template template = configuration.getTemplate("hello.ftl");
// 创建数据集
Map<String, Object> data = new HashMap<String, Object>();
data.put("hello", "hello freemarker!");
Student student = new Student(1, "jack", "18");
data.put("student", student);
List<Student> list = new ArrayList<>();
list.add(new Student(1, "小明1", "11"));
list.add(new Student(2, "小明2", "12"));
data.put("stuList", list);
data.put("date", new Date());
// 创建输出流
Writer out = new FileWriter("D:/temp/freemarker/hello.html");
// 生成静态页面
template.process(data, out);
// 关流
out.close();
}
}
5.FTL指令
1. assign指令
(1)简单类型
<#assign linkman="周先生">
联系人:${linkman}
(2)对象类型
<#assign info={"mobile":"13301231212",'address':'北京市昌平区王府街'} >
电话:${info.mobile} 地址:${info.address}
2. include指令
引入其他模板文件
<#include "head.ftl">
3.if指令
map.put("success", true);
<#if success=true>
你已通过实名认证
<#else>
你未通过实名认证
</#if>
4.list指令(遍历集合)
----商品价格表----<br>
<#list goodsList as goods>
${goods_index+1} 商品名称: ${goods.name} 价格:${goods.price}<br>
</#list>