`
longgangbai
  • 浏览: 7340159 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

在應用程序中非view层访问Freemarker

阅读更多

Freemarker访问的工具类

package com.unutrip.template.util;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.StringWriter;
import java.util.Properties;

import org.apache.log4j.Logger;

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

/**
 * 访问FreeMarker的工具类
 *
 * @author longgangbai
 *
 */
public class FreeMarkerUtils {

 private static final Logger logger = Logger
   .getLogger(FreeMarkerUtils.class);
 /**
  *
  */
 private static Configuration cfg = new Configuration();
 /**
  * 设置freemarker的资源文件目录
  */
 private static String resourceLocation = "/freemarker/";

 public FreeMarkerUtils() {
 }

 static {
  try {
   InputStream in = new FileInputStream(new File(Template.class
     .getResource(resourceLocation).getFile()
     + File.separator + "freemarker.properties"));
   Properties p = new Properties();
   p.load(in);
   // cfg.setTemplateUpdateDelay(0);
   // cfg.setSetting("number_format", "#");
   // cfg.setTagSyntax(Configuration.SQUARE_BRACKET_TAG_SYNTAX);
   // cfg.setSharedVariable("startupTime", (new Date()).getTime());
   cfg.setDirectoryForTemplateLoading(new File(Template.class
     .getResource(resourceLocation).getFile()));
   cfg.setObjectWrapper(new DefaultObjectWrapper());
   cfg.setSettings(p);
  } catch (Exception e) {
   logger.error("loader the freemarker config is error!");
   e.printStackTrace();
  }
 }

 /**
  * 外部访问的方法
  *
  * @param tmplateName
  * @param model
  * @return
  * @throws IOException
  * @throws TemplateException
  */
 public static String processTemplateIntoString(String tmplateName,
   Object model) throws IOException, TemplateException {
  Template template = cfg.getTemplate(tmplateName);
  StringWriter result = new StringWriter();
  template.process(model, result);
  return result.toString();
 }

}
# 設置标签的格式 tag_syntax = square_bracket||auto_detect
tag_syntax = auto_detect
classic_compatible=true
#鐠佸墽鐤嗛弫鏉跨摟閺嶇厧绱� 娴犮儱鍘ら崙铏瑰箛 000.00
number_format=\#
#检测更新的時間
template_update_delay=0
#設置編碼格式
default_encoding=utf-8
#設置時間的格式化

date_format=yyyy-MM-dd
time_format=HH\:mm\:Ss
datetime_format=yyyy-MM-dd HH:mm:Ss

 

ftl文件如下:

時間格式化如下:

<html>
<body>

<#list members as member>
  hotelName ${member.hotelName}
</#list>
</body>
<#list membersMap?keys as itemKey>  
<#assign item = membersMap[itemKey]>
          hotelName ${item.hotelName}   checkinDate ${item.checkindate?string('yyyy-MM-dd ')}                                      
</#list>

</body>
</html>

测试类:

package com.unutrip.template.test;

import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.commons.lang.time.DateUtils;

import com.unutrip.template.model.Order;
import com.unutrip.template.util.FreeMarkerUtils;

public class FreeMarkerTest {
 public static void main(String[] args) throws Exception {
  String freetmp = "email.ftl";
  Map model = new HashMap();

  // 一般的對象
  Order order = new Order();
  order.setCustomerName("wuxc");
  order.setHotelName("汉庭酒家");
  order.setOrderNo("00009");
  order.setRoomName("4567");
  order.setCheckindate(new Date());
  model.put("order", order);

  // 集合對象
  List<Order> orders = new ArrayList<Order>();
  for (int i = 1; i < 6; i++) {
   Order order0 = new Order();
   order0.setCheckindate(DateUtils.add(new Date(),
     Calendar.DAY_OF_MONTH, i));
   order0.setCustomerName("customerName--" + i);
   order0.setHotelName("如家大酒店");
   order0.setOrderNo("001");
   order0.setRoomName("200" + i);
   orders.add(order0);
  }
  model.put("members", orders);

  // 存放Map
  Map membersMap = new HashMap();
  membersMap.put("key", order);
  model.put("membersMap", membersMap);
  System.out.println("From Freemarker ="
    + FreeMarkerUtils.processTemplateIntoString(freetmp, model));

 }

}

Freemarker帮助文档:http://freemarker.org/docs/ref_directive_list.html

            http://www.zhuoda.org/lunzi/83461.html

freemarker语法

常用语法
 EG.一个对象BOOK
  1.输出 $...{book.name}
空值判断:$...{book.name?if_exists },
$...{book.name?default(‘xxx’)}//默认值xxx
$...{ book.name!"xxx"}//默认值xxx
日期格式:$...{book.date?string('yyyy-MM-dd')}
数字格式:$...{book?string.number}--20
$...{book?string.currency}--<#-- $20.00 -->
$...{book?string.percent}—<#-- 20% -->
插入布尔值:
<#assign foo=true />
$...{foo?string("yes","no")} <#-- yes -->

 】内置方法

一:数字型
<#assign answer=42/>
$...{answer}
$...{answer?string}  <#-- the same as $...{answer} -->
$...{answer?string.number}
$...{answer?string.currency}
$...{answer?string.percent}

<#setting number_format="0.###E0"/>

$...{12345?string("0.####E0")} 


$...{answer?string("number")} 等同于:$...{answer?string.number}.

二:日期型:
预定义格式包括:short ,middle和long。


$...{openingTime?string.short}
$...{openingTime?string.medium}
$...{openingTime?string.long}
组合使用:$...{lastUpdated?string.short_long}
$...{lastUpdated?string("yyyy-MM-dd HH:mm:ss zzzz")}

三:逻辑型
foo?string
foo?string("yes", "no")四:序列的内置方法:
first

last

seq_contains
$...{x?seq_contains("blue")?string("yes", "no")}

seq_index_of

seq_last_index_of

reverse

size

sort

sort_by
多层次的hash排序

<#assign members = [
    ...{"name": ...{"first": "Joe", "last": "Smith"}, "age": 40},
    ...{"name": ...{"first": "Fred", "last": "Crooger"}, "age": 35},
    ...{"name": ...{"first": "Amanda", "last": "Fox"}, "age": 25}]>
Sorted by name.last:
<#list members?sort_by(['name', 'last']) as m>
- $...{m.name.last}, $...{m.name.first}: $...{m.age} years old
</#list>

chunk:将一个序列分解成几个序列。

<#assign seq = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']>

<#list seq?chunk(4) as row>
  <#list row as cell>$...{cell} </#list>
</#list>

<#list seq?chunk(4, '-') as row>
  <#list row as cell>$...{cell} </#list>
</#list>
chunk经常用于分栏或者表格输出的格式。

五:hash内置方法:

keys:
values:

】序列 由逗号分隔的变量列表,由方括号限定,类似java中的一维数组

<#assign seq = ["winter", "spring", "summer", "autumn"]>
<#list seq as x>
  ${x_index + 1}. ${x}

<#if x_has_next>,

</#list>

输出
  1. winter,
  2. spring,
  3. summer,
  4. autumn  

】Hashes(散列)-由逗号分隔的键-值列表,由大括号限定,键和值之间用冒号分隔:{"name":"green mouse", "price":150},键和值都是表达式,但是键必须是字符串。

<#assign ages = ...{"Joe":23, "Fred":25} + ...{"Joe":30, "Julia":18}>
- Joe is $...{ages.Joe}
- Fred is $...{ages.Fred}
- Julia is $...{ages.Julia} 结果:
- Joe is 30
- Fred is 25
- Julia is 18
】freemarker的空值和默认值

${user?if_exists}      

${user?default('your name')}

判断对象是不是null
<#if mouse?exists>
      Mouse found
<#else>

或<#if book.name?? >

 Mouse found

</#if>
list 空值判断  <#if bookList?size = 0>


】算术运算

 

比较操作符-<#if expression>...</#if>
1.)使用=(或==,完全相等)测试两个值是否相等,使用!= 测试两个值是否不相等
2.)=和!=两边必须是相同类型的值,否则会产生错误,例如<#if 1 = "1">会引起错误
3.)Freemarker是精确比较,所以"x"、"x  "和"X"是不相等的
4.)对数字和日期可以使用<、<=、>和>=,但不能用于字符串
5.)由于Freemarker会将>解释成FTL标记的结束字符,所以对于>和>=可以使用括号来避免这种情况,例如<#if (x > y)>,另一种替代的方法是,使用lt、lte、gt和gte来替代<、<=、>和>=

逻辑操作符-&&(and)、||(or)、!(not),只能用于布尔值,否则会产生错误
<#if x < 12 && color = "green">
  We have less than 12 things, and they are green.
</#if>
<#if !hot> <#-- here hot must be a boolean -->
  It's not hot.
</#if> 

内置函数-用法类似访问hash(散列)的子变量,只是使用"?"替代".",例如:user?upper_case
下面列出常用的一些函数:
对于字符串
html-对字符串进行HTML编码
cap_first-使字符串第一个字母大写
lower_case-将字符串转换成小写
trim-去掉字符串前后的空白字符
对于Sequences(序列)
size-获得序列中元素的数目
对于数字
int-取得数字的整数部分(如-1.9?int的结果是-1)

例一:

<#-- test的值为Tom & Jerry -->
$...{test?html}
$...{test?upper_case?html}
结果:
Tom &amp; Jerry
TOM &amp; JERRY

例二:

<#-- seasons的值为"winter", "spring", "summer", "autumn" -->
$...{seasons?size}
$...{seasons[1]?cap_first} <#-- left side can by any expression -->
$...{"horse"?cap_first} 
结果:
4
Spring
Horse 

方法的调用
$...{repeat("What", 3)}
$...{repeat(repeat("x", 2), 3) + repeat("What", 4)?upper_case}
结果:
WhatWhatWhat
xxxxxxWHATWHATWHATWHAT

操作符优先顺序
后缀            [subvarName] [subStringRange] . (methodParams)
一元            +expr、-expr、!
内建            ?
乘法            *、 / 、%
加法            +、-
关系            <、>、<=、>=(lt、lte、gt、gte)
相等            =、!=
逻辑            &&
逻辑            ||
数字范围      ..

三.) Interpolation:由$...{...}或#...{...}两种类型,输出计算值,可以定义输出的格式
例一:

<#setting number_format="currency"/>
<#assign answer=42/>
$...{answer}
$...{answer?string}  <#-- the same as $...{answer} -->
$...{answer?string.number}
$...{answer?string.currency}
$...{answer?string.percent}
结果:
$42.00
$42.00
42
$42.00
4,200%

例二:

$...{lastUpdated?string("yyyy-MM-dd HH:mm:ss zzzz")}
$...{lastUpdated?string("EEE, MMM d, ''yy")}
$...{lastUpdated?string("EEEE, MMMM dd, yyyy, hh:mm:ss a '('zzz')'")} 
结果:
2003-04-08 21:24:44 Pacific Daylight Time
Tue, Apr 8, '03
Tuesday, April 08, 2003, 09:24:44 PM (PDT)

例三:

<#assign foo=true/>
$...{foo?string("yes", "no")}
结果:
yes

例四:

<#-- x is 2.582 and y is 4 -->
#...{x; M2}   <#-- 2.58 -->
#...{y; M2}   <#-- 4    -->
#...{x; m1}   <#-- 2.6 -->
#...{y; m1}   <#-- 4.0 -->
#...{x; m1M2} <#-- 2.58 -->
#...{y; m1M2} <#-- 4.0  --> 
说明:mX-小数部分最小X位;MX-小数部分最大X位。

四.) 注释:<#--和-->

下面是一个常用的模板例子:

<p>We have these animals:
<table border=1>
  <tr><th>Name<th>Price
  <#list animals as being>
  <tr>
    <td>
      <#if being.size = "large"><b></#if>
      $...{being.name}
      <#if being.size="large"></b></#if>
    <td>$...{being.price} Euros
  </#list>
 </table>
<#include "/copyright_footer.html">
注意点:
1.) FreeMarker是区分大小写的;
2.) FTL标记不能位于另一个FTL标记内部,例如:<#if <#include 'foo'>='bar'>...</if>;
3.) $...{…}只能在文本中使用;
4.) 多余的空白字符会在模板输出时去除;
5.) 如果使用的指令不存在,会产生一个错误消息。
<#-- x的值设定为5 -->
$...{x * x - 100}
$...{x / 2}
$...{12 % 10}
结果:
-75
2.5
2

注意: 操作符两边必须是数字;使用"+"时,如果一边是数字,一边是字符串,就会自动将数字转换为字符串。

使用内建的指令int获得整数部分:

$...{(x/2)?int}
$...{1.1?int}
$...{1.999?int}
$...{-1.1?int}
$...{-1.999?int}
结果:
2
1
1
-1
-1

 

分享到:
评论

相关推荐

    freemarker中文API手册

    FreeMarker中文API手册 FreeMarker是一种模板引擎,...FreeMarker是一个功能强大且灵活的模板引擎,广泛应用于Web应用程序和非Web应用程序环境,提供了强大的模板语言和灵活的数据模型,能够满足不同开发者的需求。

    freemarker 自定义freeMarker标签

    2. 注册自定义指令:在你的应用程序中,你需要将自定义指令类注册到FreeMarker配置中。这通常是通过`Configuration`对象的`setSharedVariable`方法完成的,将你的自定义指令类实例绑定到一个特定的名字,这个名字...

    Freemarker简介及标签详解大全

    2. Freemarker 可以应用于非 Web 应用程序环境。 3. Freemarker 可以与容器无关,因为它并不知道 HTTP 或 Servlet。 4. Freemarker 可以通过 Eclipse 的插件来编辑,经过验证,FreeMarker 最好的 Eclipse 编辑插件是...

    基于Freemarker代码生成程序

    Freemarker是一个开源的、基于模板的技术,广泛应用于Web应用开发中的视图层,比如JSP的替代品。它允许开发者用简单的模板语言(Template Language)定义数据如何被转换为HTML或其他格式。在本项目中,Freemarker被...

    freemarker简单示例

    FreeMarker允许Java servlet保持图形设计同应用程序逻辑的分离,这是通过在模板中密封HTML完成的。模板用servlet提供的数据动态地生成 HTML。模板语言是强大的直观的,编译器速度快,输出接近静态HTML页面的速度。 ...

    freemarker-2.3.23jar

    这些变量通常由应用程序(如Java后端)提供,Freemarker负责根据模板和数据生成最终的输出。 具体到`2.3.23`这个版本,它可能包括以下特性: 1. **模板设计**:Freemarker支持多种模板设计,如HTML、XML、邮件模板...

    访问FreeMarker的工具类

    FreeMarker是一个强大的、开源的模板引擎,常用于Java Web应用中的动态内容生成,例如电子邮件、网页等。FreeMarker与Spring框架结合使用时,可以轻松实现视图层的模板渲染。`FreeMarkerUtils`是一个常见的工具类,...

    hudson.freemarker_ide_0.9.14

    FreeMarker允许Java servlet保持图形设计同应用程序逻辑的分离,这是通过在模板中密封HTML完成的。 模板用servlet提供的数据动态地生成 HTML。模板语言是强大的直观的,编译器速度快,输出接近静态HTML页面的速度...

    FreeMarker应用实例和PPT

    本实例将深入探讨FreeMarker在Struts2中的应用,以及如何通过PPT形式进行演示。 1. **FreeMarker的基本概念** - **模板语言**:FreeMarker使用简单的文本文件作为模板,其中包含动态和静态内容的混合,动态内容由...

    Freemarker中List的应用

    Freemarker是一个强大的模板引擎,常用于Java应用中的视图层渲染,比如Spring MVC框架。它允许开发者使用简单的模板语言来动态生成HTML或其他格式的文本。在Freemarker中,`List`是一种非常常用的数据结构,它允许...

    freemarker Demo 适用于freemarker初学

    Freemarker是一个强大的模板引擎,常用于JavaEE应用中的视图层处理,尤其与Struts2等MVC框架配合使用,能实现灵活的动态页面渲染。这个"freemarker Demo"是一个适合初学者的示例项目,旨在帮助新接触Freemarker的...

    FreeMarker手册-Freemarker 2.3.18

    在Web应用中,FreeMarker常与Model-View-Controller(MVC)模式结合使用,控制器将处理业务逻辑,模型提供数据,而FreeMarker作为视图负责渲染输出。 8. **错误处理和调试** FreeMarker提供了丰富的错误处理机制...

    freemarker概述

    FreeMarker的主要用途是生成HTML网页,尤其是在MVC(Model-View-Controller)架构的应用程序中。 #### 二、FreeMarker的功能特性 FreeMarker不仅限于生成HTML,还可以生成XML、Java源代码、电子邮件等各类文本文件...

    spring mvc freemarker 简单例子

    Spring MVC 是一个基于Spring框架的Model-View-Controller架构,用于构建高效、灵活的Web应用程序。而Freemarker 是一款强大的模板引擎,它与后端数据模型相结合,生成动态HTML或其他格式的文档。 在Spring MVC中,...

    在struts2中使用freemarker模版

    Struts2是一个强大的Java web应用程序框架,它提供了一种组织应用程序的方式,并且支持多种视图技术,其中之一就是FreeMarker模板。FreeMarker是一个基于模板的、声明式的语言,用于生成动态内容,尤其适合Web应用中...

    FreeMarker

    FreeMarker的设计理念是将表现层(视图)和业务逻辑层(控制器)分离,从而实现MVC(Model-View-Controller)架构中的“View”部分。 FreeMarker的核心概念是模板文件,这是一种特殊的文本文件,其中包含可替换的...

    struts2和freemarker整合

    Struts2是一个基于MVC(Model-View-Controller)架构模式的开源框架,用于构建动态、数据驱动的Web应用程序,而FreeMarker则是一个模板引擎,它允许开发者将业务逻辑与视图层分离,使得前端展示更加灵活和高效。...

    struts2-freemarker

    Struts2是一个强大的MVC(Model-View-Controller)框架,它极大地简化了构建基于Java的Web应用程序的过程。而FreeMarker则是一种模板引擎,主要用于生成动态HTML或其他类型的文本文件。它们的整合使得开发者能够更加...

    freemarker-2.3.28.jar

    在实际应用中,开发者通常会将这个JAR文件添加到项目的类路径(classpath)中,以便在运行时能够解析和执行Freemarker模板。如果在Eclipse中使用,可以将该JAR文件添加到项目的构建路径,确保项目能正确识别并利用...

Global site tag (gtag.js) - Google Analytics