FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java 等。
FreeMarker的原理其实就是字符串的替换,可以动态的生成不同的页面代码只需要写一份就可以了,这样可以使访问页面更加迅捷,它跟servlet无关,也不需要tomcat,不如京东的商品的页面,每点进去一个页面,样子都一样,只不过就是内容不同,这时候就可以写一个模板的html,然后动态的生成别的html就可以了.
导入依赖
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.23</version>
</dependency>
测试代码
package cn.e3mall.freemarker;
import java.io.File;
import java.io.FileWriter;
import java.io.Writer;
import java.util.HashMap;
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 {
//1、创建一个模板文件
//2、创建一个Configuration对象
Configuration configuration = new Configuration(Configuration.getVersion());
//3、设置模板文件保存的目录
configuration.setDirectoryForTemplateLoading(new File("D:/workspaces-itcast/JavaEE32/e3-item-web/src/main/webapp/WEB-INF/ftl"));
//4、模板文件的编码格式,一般就是utf-8
configuration.setDefaultEncoding("utf-8");
//5、加载一个模板文件,创建一个模板对象。
Template template = configuration.getTemplate("hello.ftl");
//6、创建一个数据集。可以是pojo也可以是map。推荐使用map
Map data = new HashMap<>();
data.put("hello", "hello freemarker!");
//7、创建一个Writer对象,指定输出文件的路径及文件名。 就是生成文件的位置,什么文件都可以生成这以txt为例
Writer out = new FileWriter(new File("D:/temp/JavaEE32/freemarker/hello.txt"));
//8、生成静态页面
template.process(data, out);
//9、关闭流
out.close();
}
}
默认文件,尾缀其实什么都可以,只不过一般都是ftl,里面用${}的形式写变量,其实跟el表达式差不多就当el表达式用就行了
![](https://img-blog.csdnimg.cn/20190108190049715.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
运行完后就在本地生成一个文件,就把那个表达式替换成代码里的字符串了.
![](https://img-blog.csdnimg.cn/20190108190410872.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20190108190434438.png)
如何取pojo属性,其实跟el表达式也一样
![](https://img-blog.csdnimg.cn/20190111140542294.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
然后还是上面的测试类中,创建一个对象写进去
![](https://img-blog.csdnimg.cn/20190111140709366.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20190111140820440.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20190111140840401.png)
如果取list集合,添加一个list取名为stuList
![](https://img-blog.csdnimg.cn/20190111141046437.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
页面中循环展示就是以<#list>这个标签开头,后面加传的时候起的名字,as后面写起的别名,通过别名把一个个实体取出来
![](https://img-blog.csdnimg.cn/20190111141118898.png)
![](https://img-blog.csdnimg.cn/20190111141222414.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
加一个${stu_index}就是取下标从0开始
![](https://img-blog.csdnimg.cn/20190111141410459.png)
![](https://img-blog.csdnimg.cn/20190111141446886.png)
if,else语句,如果能被2整除就加个红色,不能就加绿色
![](https://img-blog.csdnimg.cn/20190111141650778.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20190111141717323.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2t4ajE5OTgwNTI0,size_16,color_FFFFFF,t_70)
展示日期格式
![](https://img-blog.csdnimg.cn/20190111142719334.png)
取的时候格式${自定义的名字?date}
![](https://img-blog.csdnimg.cn/20190111142746855.png)
![](https://img-blog.csdnimg.cn/20190111142821748.png)
![](https://img-blog.csdnimg.cn/20190111142835653.png)
![](https://img-blog.csdnimg.cn/201901111428521.png)
![](https://img-blog.csdnimg.cn/2019011114290516.png)
![](https://img-blog.csdnimg.cn/20190111142918695.png)
自定义时间格式
![](https://img-blog.csdnimg.cn/20190111142936271.png)
![](https://img-blog.csdnimg.cn/20190111142958417.png)
空值的判断,有可能有些时候我们提供是数据为null怎么解决,直接取会报错,这儿测试就直接添加一个null
![](https://img-blog.csdnimg.cn/20190111143242524.png)
前台页面取的时候,如果直接写${val}就会报错,后面加!的意思是!后面表示如果该值为null显示!后面的值
![](https://img-blog.csdnimg.cn/20190111143349977.png)
![](https://img-blog.csdnimg.cn/20190111143451860.png)
![](https://img-blog.csdnimg.cn/20190111143502534.png)
![](https://img-blog.csdnimg.cn/20190111143517193.png)
判断一个值是否为null,val??表示不为null
![](https://img-blog.csdnimg.cn/20190111143554689.png)
![](https://img-blog.csdnimg.cn/20190111143609229.png)
<#include>引用别的模板,把另一个模板内容引用过来
![](https://img-blog.csdnimg.cn/20190111143718189.png)
![](https://img-blog.csdnimg.cn/20190111143801929.png)