1、FreeMarker介紹:css
FreeMarker是一個用Java語言編寫的模板引擎,它基於模板來生成文本輸出。FreeMarker與Web容器無關,即在Web運行時,它並不知道Servlet或HTTP。它不只能夠用做表現層的實現技術,並且還能夠用於生成XML,JSP或Java 等。html
優勢:java
FreeMarker容許Java servlet保持圖形設計同應用程序邏輯的分離,程序員
這是經過在模板中密封HTML完成的。模板用servlet提供的數據動態地生成 HTML。web
模板語言是強大的直觀的,編譯器速度快,輸出接近靜態HTML頁面的速度。編程
雖然FreeMarker具備一些編程的能力,但一般由Java程序準備要顯示的數據,app
由FreeMarker生成頁面,經過模板顯示準備的數據。框架
通用數據模型jsp
FreeMarker不是直接反射到Java對象,Java對象經過插件式對象封裝,以變量方式在模板中顯示。ui
可使用抽象(接口)方式表示對象(JavaBean、XML文檔、SQL查詢結果集等等),
告訴模板開發者使用。方法,使其不受技術細節的打擾。
爲Web準備
在模板語言中內建處理典型Web相關任務(如HTML轉義)的結構。
可以集成到Model2 Web應用框架中做爲JSP的替代。
支持JSP標記庫。
爲MVC模式設計:分離可視化設計和應用程序邏輯;分離頁面設計員和程序員。
2、在 web中的配置:
一、建立一個動態的web項目FreeMarkerTest,並在lib中加入freemarker的jar 包
二、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>
三、在WebRoot 下建立一個模板文件 /ftl/test.ftl
<#macro m1> <#--定義指令m1 --> <b>aaabbbccc</b> <b>dddeeefff</b> </#macro>
四、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