现在的位置: 首页 > 综合 > 正文

1、freemarker入门

2018年02月05日 ⁄ 综合 ⁄ 共 2365字 ⁄ 字号 评论关闭

什么是FreeMarker?

FreeMarker是一款模板引擎:即一种基于模板、用来生成输出文本的通用工具。它是为Java程序员提供的一个开发包,或者说是一个类库。
FreeMarker实际上是被设计用来生成HTML页面,尤其是通过实现了基于MVC(Model View Controller,模型-视图-控制器)模式的Java Servlet应用程序。使用MVC模式的动态页面的设计构思使得你可以将前端设计师(编写HTML页面的人员)从程序员中分离出来。那么,所有人各司其职,发挥其最擅长的一面。网页设计师可以改写页面的显示效果而不受程序员编译代码的影响,因为应用程序的逻辑(这里是Java程序)和页面设计(这里是FreeMarker模板)已经被分开了。页面模板代码不会受到复杂程序代码的影响。这种分离的思想即便对一个程序员和页面设计师是同一个人的项目来说也都是非常有用的,因为分离使得代码保持简洁而且易于维护。

它的大体思路图:

模板+数据模型 = 输出

首先来看一看环境的搭建,FreeMarker不是Web开发的应用程序框架。FreeMarker引擎本身并不知道HTTP协议或Java Servlet的存在。它仅仅来生成文本内容。所以在myeclipse中新建java项目就可以了。

具体步骤:

1、新建java项目

2、下载freemarker的jar包

3、引入freemarker开发jar包,通过项目的build path-->configure build path...-->Add Externals Jars加入freemarker.jar

4、编写测试程序

package com.cdtax.freemarker;

import java.io.File;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.HashMap;
import java.util.Map;

import freemarker.template.Configuration;
import freemarker.template.DefaultObjectWrapper;
import freemarker.template.Template;

public class Test1
{
	public static void main(String[] args) throws Exception
	{
		//Configuration实例是存储FreeMarker应用级设置的核心部分
		Configuration cfg = new Configuration();
		
		// 指定模板文件从何处加载的数据源,这里设置成一个文件目录。
		File path1 = new File(System.getProperty("user.dir")+"/src/ceshi");
		cfg.setDirectoryForTemplateLoading(path1);
		
		// 指定模板如何检索数据模型,这是一个高级的主题了…
		// 但先可以这么来用:
		cfg.setObjectWrapper(new DefaultObjectWrapper());
		
		//获得模板
		Template temp = cfg.getTemplate("test.ftl");
		
		// 创建根哈希表
		Map root = new HashMap();
		
		// 在根中放入字符串"user"
		root.put("user", "xiaoming");
		
		// 为"latestProduct"创建哈希表
		Map latest = new HashMap();
		
		// 将它添加到根哈希表中
		root.put("latestproduct", latest);
		
		// 在latest中放置"url"和"name"
		latest.put("url", "products/greenmouse.html");
		latest.put("name", "green mouse");
		
		Writer out = new OutputStreamWriter(System.out);
		// 将模板和数据模型合并 并输出
		temp.process(root, out);
		out.flush();
	}
}

模板文件test.ftl:

<html>
<head>
	<title>welcome!</title>
</head>
<body>
	<h1>welcome ${user} !</h1>
	<p>our latest products:
	<a href="${latestproduct.url}">${latestproduct.name}</a>!

运行的结果:

<html>
<head>
<title>welcome!</title>
</head>
<body>
<h1>welcome xiaoming !</h1>
<p>our latest products:
<a href="products/greenmouse.html">green mouse</a>!

如果将结果输出到一个文件中,如a.html,那么就成了一个页面。

总了的来说,编程分为四步:

0、前置条件:编写模板文件(.ftl文件)

1、创建Configuration实例(freemarker的核心配置对象),然后调整配置,设定模板文件存放的位置(具体的存放目录),在整个应用的生命周期中,这个工作你应该只做一次。 

2、然后获取或创建模板,在整个应用的生命周期中,这个工作你可以执行多次

3、创建数据模型,数据应该由业务层产生,有一个domain域模型(如前面ssh中的Employee类),最后转换成map类型数据。

4、将模板和数据模型合并

从上面的图中能够看出,freemarker知识主要分模板知识部分,数据模型部分,以及配置及合并等。

抱歉!评论已关闭.