项目中用到了FreeMarker,就上网找了很多有关的知识,自己总结了一下。
一、FreeMarker介绍:
FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或 HTTP 。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java 等。
优点:
FreeMarker允许 Java servlet 保持 图形设计 同 应用程序 逻辑的分离,
这是通过在模板中密封 HTML 完成的。 模板 用 servlet 提供的数据动态地生成 HTML。
模板语言是强大的直观的, 编译器 速度快,输出接近 静态 HTML页面的速度。
虽然FreeMarker具有一些 编程 的能力,但通常由Java程序准备要显示的数据,
由FreeMarker生成页面,通过模板显示准备的数据。
通用数据模型
FreeMarker不是直接反射到Java对象,Java对象通过插件式对象封装,以变量方式在模板中显示。
可以使用抽象(接口)方式表示对象( JavaBean 、 XML 文档、 SQL 查询结果集等等),
告诉模板开发者使用。方法,使其不受技术细节的打扰。
为Web准备
在模板语言中内建处理典型Web相关任务(如 HTML 转义)的结构。
能够集成到Model2 Web应用框架中作为JSP的替代。
支持JSP标记库。
为MVC模式设计:分离可视化设计和 应用程序 逻辑;分离页面设计员和程序员。
二、在 web中的配置:
1、创建一个动态的web项目FreeMarkerTest,并在lib中加入freemarker的jar 包
2、web.xml配置:
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <servlet> <servlet-name>freemarker</servlet-name> <servlet-class>freemarker.ext.servlet.FreemarkerServlet</servlet-class> <!-- FreemarkerServlet settings: --> <init-param> <param-name>TemplatePath</param-name> <param-value>/</param-value> </init-param> <init-param> <param-name>NoCache</param-name> <param-value>true</param-value> </init-param> <init-param> <param-name>ContentType</param-name> <param-value>text/html</param-value> </init-param> <init-param> <param-name>template_update_delay</param-name> <param-value>0</param-value> <!-- 0 is for development only! Use higher value otherwise. --> </init-param> <init-param> <param-name>locale</param-name> <param-value>zh_CN</param-value> </init-param> <init-param> <param-name>default_encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>boolean_format</param-name> <param-value>true,false</param-value> </init-param> <init-param> <param-name>datetime_format</param-name> <param-value>yyyy-MM-dd HH:mm:ss</param-value> </init-param> <init-param> <param-name>date_format</param-name> <param-value>yyyy-MM-dd</param-value> </init-param> <init-param> <param-name>time_format</param-name> <param-value>HH:mm:ss</param-value> </init-param> <init-param> <param-name>number_format</param-name> <param-value>0.##########</param-value> </init-param> <!--自动导入模板 标签为p--> <init-param> <param-name>auto_import</param-name> <param-value>/ftl/test.ftl as p</param-value> </init-param> </servlet> <!-- freemarker--> <servlet-mapping> <servlet-name>freemarker</servlet-name> <url-pattern>*.html</url-pattern> </servlet-mapping> </web-app>
3、在WebRoot 下创建一个模板文件 /ftl/test.ftl
<#macro m1> <#--定义指令m1 --> <b>aaabbbccc</b> <b>dddeeefff</b> </#macro>
4、index.html 中引用:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>index.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> </head> <body> This is my HTML page. <br> <!-- 引用模板标签 --> <@p.m1 /> </body> </html>
5,启动服务访问: http://localhost:8080/FreeMarkerTest/index.html
显示:
This is my HTML page.
aaabbbccc dddeeefff