freemarker入門例子


1.把包lib/freemarker.jar拷貝到項目中

 

2.新建模板文件WEB-INF/templates/test.ftl,內容如下:

Hello,${name}!

3.新建一個操作類Class1.java,(把模板裝載到jsp頁面中).  內容如下

package com.abc.web;

import java.io.Writer;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.jsp.PageContext;

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

public class Class1 {
public void execute(PageContext pageContext)throws Exception
{
Configuration cfg =new Configuration();
cfg.setServletContextForTemplateLoading(pageContext.getServletContext(), "WEB-INF/templates");

Map root =new HashMap();
root.put("name","Tom");

Template t = cfg.getTemplate("test.ftl");

Writer out = pageContext.getResponse().getWriter();

t.process(root, out);
}
}

4.新建一個jsp頁面test1.jsp,內容如下:

<%@ page language="java" contentType="text/html; charset=GB2312"
pageEncoding
="GB2312"%>
<%@ pageimport="com.abc.web.Class1"%>
<!DOCTYPE html PUBLIC"-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312">
<title>Insert title here</title>
</head>
<body>
<%
Class1 c1 =new Class1();
c1.execute(pageContext);
%>
</body>
</html>

頁面的顯示效果為:

Hello,Tom!

 
--------------------------------------------------------只使用一個模板頁,沒有使用jsp頁面------------------------------------
 
1.把包lib/ freemarker.jar拷貝到項目中

2.  在WEB-INF下新建文件夾templates  在templates下新建test.ftl文件

內容為:

<html>

  <head>      <title>Hello Word</title>     </head> 

   <body>        

<h3>${message},${name}</h3> 

    </body> 

</html> 

3.    新建Servlet,內容如下:

package com.njy.freemarker.servlet;

import java.io.IOException;
import java.io.Writer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;

public class HelloFreeMarker extends HttpServlet {

 public HelloFreeMarker() {
  super();
 }

 //負責管理FreeMarker模板的Configuration實例
 private Configuration cfg = null;
 
 public void init() throws ServletException {
  //創建一個FreeMarker實例
  cfg = new Configuration();
  //指定FreeMarker模板文件的位置
  cfg.setServletContextForTemplateLoading(getServletContext(),"/WEB-INF/templates");
 }
 
 public void doGet(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {
  doPost(request, response);
 }

 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  //建立數據模型
  Map root = new HashMap();
  root.put("message", "hello world");
  root.put("name", "聶靖宇");
  root.put("personList", list);
  
  //獲取模板文件
  Template t = cfg.getTemplate("test.ftl");
  
  //開始准備生成輸出
  //- 使用模板文件的Charset作為本頁面的charset
  //- 使用text/html MIME-type
  response.setContentType("text/html; charset=" + t.getEncoding());
  Writer out = response.getWriter();
  //合並數據模型和模板,並將結果輸出到out中
  try {
   t.process(root, out); // 往模板里寫數據
  } catch (TemplateException e) {
   e.printStackTrace();
  }
 }

 public void destroy() {
  super.destroy();
 }
}
4web.xml中配置servlet

<servlet>
    <servlet-name>HelloFreeMarker</servlet-name>
    <servlet-class>com.njy.freemarker.servlet.HelloFreeMarker</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>HelloFreeMarker</servlet-name>
    <url-pattern>/hello</url-pattern>
  </servlet-mapping>

5.    運行http://localhost:8080/freemarkerTest/hello,頁面效果如下如所示:

hello world,聶靖宇

小一 11 11.01 小二 12 12.02 小三 13 13.03 小四 14 14.04 小五 15 15.05 this is a Child! this is a Child! this is a Child! this is a Child! this is a Child!

-----------------------------------------------------一些相關知識點-------------------------------------------------------------

1模板+數據模型=輸出

2數據模型一覽

<html>
<head>
  <title>Welcome!</title>
</head>
<body>
  <h1>Welcome ${user}!</h1>
  <p>Our latest product:
  <a href="${latestProduct.url}">${latestProduct.name}</a>!
</body>
</html>  

 模板能用的所有數據被包裝成data-model數據模型。 
(root)
  |
  +- user = "Big Joe"
  |
  +- latestProduct
      |
      +- url = "products/greenmouse.html"
      |
      +- name = "green mouse"

 
 
3相關標簽
     Welcome ${user}<#if user == "Big Joe">, our beloved leader</#if>!

<#list whatnot.fruits as fruit>
 <li>${fruit}
</#list>
 
<#include "/copyright_footer.html">
 
4內建函數
${'abc'?substring(0, 1)}        a
${"  green mouse"?cap_first}  Green mouse
注意如果你想安全地插入一個屬性,你必須在HTML模板中使用引號標記(是",而不
是')為屬性值加引號:
<input type=text name=user value="${user?html}">


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM