FreeMarker是一个模版引擎,一个基于模版生成文本输出的通用工具,使用纯Java编写。FreeMarker被设计用来生成HTML Web页面,特别是基于MVC模式的应用程序。FreeMarker有一些编成能力,但通常情况下用java程序准备要显示的数据,由FreeMarker生成页面,通过模版显示准备的数据。FreeMarker不是一个Web应用框架,而更适合作为一个Web应用框架的一个组件。FreeMarker与容器无关,它并不知道HTTP或者Servlet,FreeMarker同样可以用于非Web应用环境。FreeMarker更适合Model2的视图组件,同样可以在模版中使用JSP标记库。
FreeMarker的通用目标:能够生成各种文本,HTML、XML、RTF、Java源代码等等;易于嵌入,轻量级、不需要Servlet环境;插件式的模版载入器,可以在任何源载入,如本地文件、数据库等等;按需生成文本,保存到本地文件、作为Email发送、从Web应用程序发送它返回到Web浏览器。
强大的模版语言:所有常用的指令,include、if/elseif/else、循环结构。在模板中创建和改变变量。可以使用复杂的表达式来使用值。命名的宏,可以具有位置参数和嵌套内容。名字空间有助于建立和维护可重用的宏库,或者将一个大的工程分为若干个模块,而不必担心命名的冲突。输出转换块,在嵌套模版片断生成输出时,转换HTML转义、压缩、语法高亮等等。。
通用的数据模型:FreeMarker不是直接反映到java对象,java对象通过插件式封装,以变量的方式在模版中展示。使用抽象的方式表示对象,使其不受技术细节的打扰。
在模板语言中内建处理典型Web 相关任务(如HTML 转义)的结构
能够集成到Model2Web 应用框架中作为JSP 的替代
支持JSP 标记库
为MVC 模式设计:分离可视化设计和应用程序逻辑;分离页面设计员和程序员
5、智能的国际化和本地化
字符集智能化(内部使用UNICODE)
数字格式本地化敏感
日期和时间格式本地化敏感
非US 字符集可以用作标识(如变量名)
多种不同语言的相同模板
6、强大的XML 处理能力
<#recurse> 和<#visit>指令(2.3 版本)用于递归遍历XML 树
在模板中清楚和直觉的访问XML 对象模型
FreeMarker是一个Java模版语言,它是 JSP 的绝佳替代方案. FreeMarker在你的action result可能需要在Servlet容器环境以外被载入的情况下是理想选择. 例如,如果你希望在你的应用程序中支持plugins,你可能会乐意使用Freemarker,因为那样的话plugins可以支持将所有的action class和view都打包到一个从classloader进行装载的jar文件里面.
关于FreeMarker的更多信息,请访问FreeMarker网站.
FreeMarker与Velocity非常相似, 它们都是可以在Servlet容器外使用的模版语言. WebWork小组更推荐FreeMarker, 而不是Velocity, 这是因为FreeMarker提供了更好的错误报告, 支持JSP标签, 稍多的功能. 当然, 这两种技术都是代替JSP的很好方案.
快速上手
确认配置好你的项目的classpath中的所有依赖以后, 开始使用FreeMarker就非常简单了. 典型情况下只需要 freemarker.jar. 除它以外, webwork-default.xml已经配置好了将FreeMarker Result映射到你的模版文件. 你现在可以试验一下如下 xwork.xml 配置:
<action name="test" class="com.acme.TestAction">
<result name="success" type="freemarker">test-success.ftl</result>
</action
然后写好 test-success.ftl:
<html>
<head>
<title>Hello</title>
</head>
<body>
Hello, ${name}
</body>
</html>
这里 name 是你的action中的一个属性. 这样就可以了! 该文档的余下部分将介绍模版如何被加载, 变量如何解析, tags(标签)也可以使用.
模版加载
Webwork在两个位置查找FreeMarker模版(按顺序):
Web应用程序目录(Web application)
Class path
这个顺序对于在完全编译的jar中提供模版很理想, 但是也同时支持在Web应用程序目录中定义这些模版来覆盖jar中的模版文件. 事实上, 这就是为什么你可以覆盖WebWork中默认的UI tags和Form Tags的原理.
还有, 你可以通过templatePath 上下文变量(context variable)指定一个路径(你的文件系统中的一个目录). 如果指定了该变量, 那么这个目录中的内容将会被优先寻找.
变量解析/决定(Resolution)
在FreeMarker中, 变量将会在多个位置进行寻找, 顺序如下:
值栈(value stack)
action上下文(action context)
Request范围(scope)
Session范围(scope)
Application范围(scope)
内建变量
注意action上下文在value stack后进行搜索. 这意味着你可以引用变量而不必使用标准的符号(#)前缀,不像在JSP中使用ww:property中必须使用的那种语法(译者注:现在在JSP中也可以不用#而访问默认的ValueStack). 这是一个很好的便利特性, 但是小心, 它有时也会把你陷进去. <@ww.url id="url" value="http://www.yahoo.com"/>
Click <a xhref="${url}">here</a>!
Webwork-FreeMarker整合提供的内建变量如下:
Name Description
stack 值栈本身, 方便使用 ${stack.findString('ognl expr')}的方式调用
action 最近执行的action
response HttpServletResponse
res 与response相同
request HttpServletRequest
req 与reqeust相同
session HttpSession
application ServletContext
base request的上下文路径(context path)
标签支持
FreeMarker是很棒的模版语言, 因为它完整的支持标签(tag). 参照WebWork提供的 FreeMarker Tags 文档中的如何使用通用(generic) Tags 部分获取更多信息. 除了那些, 你还可以使用任何的JSP标签(tag), 就像这样:
<#assign mytag=JspTaglibs["/WEB-INF/mytag.tld"]>
<@mytag.tagx attribute1="some ${value}"/>
这里 mytag.tld 是你使用的JSP标签库的定义文件. 注意: 为了使用FreeMarker的这个支持, 你必须开启 web.xml 2.1.x compatibility 文档中的 JSPSupportServlet.
提示和技巧
下面是在使用FreeMarker构建WebWork应用程序时的一些有用的进阶功能.
类型转换与本地化
FreeMarker内置支持日期与数字的格式化. 格式化的规则基于action request的地区信息(locale), locale是通过webwork.properties配置的, 它也可以通过I18n Interceptor进行覆盖. 这种方式一般会完美的满足你的需求, 但是你要记住, 这些格式化信息是通过FreeMarker处理的,而不是通过WebWork的类型转换支持实现.
如果你希望WebWork根据你所指定的类型转换处理格式化, 你不应该使用平常的&{...}语法. 取而代之, 你应该使用property标签. 区别在于property标签特别为OGNL表达式设计, 计算它的值, 然后将结果用你指定的Type Conversion转换为String. 平常使用的${...}语法则会使用FreeMarker的表达式语言(EL), 计算它的值, 然后通过内建的格式化规则转化为String. 这些区别甚微, 但是一定要了解.
扩展
有时你可能需要扩展WebWork提供的FreeMarker支持. 最常见的原因是你希望引入你自己的标签, 就像你扩展WebWork内建标签一样.
如果需扩展, 首先要新建一个继承 com.opensymphony.webwork.views.freemarker.FreemarkerManager 并且重载了相应方法的类. 然后将下面代码添加到webwork.properties:
webwork.freemarker.manager.classname = com.yourcompany.YourFreeMarkerManager
ObjectWrapper设置
如果你熟悉了FreeMarker, 你会发现它的敏感性会带来一些困扰. 最常见的方法就是尝试使用FreeMarker提供的BeanWrapper. 如果你不知道那是什么,别担心. 只要知道这些酒可以了:
WebWorkBeanWrapper继承自默认的FreeMarker BeansWrapper, 提供了基本完全一致的功能, 只是修改了maps处理机制. 一般, FreeMarker有两种操作模式: 一种支持友好的内置的map (?key, ?values, etc),但是只支持String作为key; 或者特殊的内置支持(例如: ?key 返回map的相应方法而不是key), 但是它支持String和String相似的非String作为key. WebWork提供了两种情况下的可选的实现方案.
这种特殊的做法也许会让你迷惑或产生问题. 所以, 你可以将 webwork.properties 中的*webwork.freemarker.wrapper.altMap*设置为false, 允许替换为常规的BeansWrapper逻辑.
语法注释
如果是FreeMarker 2.3.4, 还支持另外的语法. 这种可选的语法在你感觉你使用的IDE(尤其是ItelliJ IDEA)在默认的语法下运行困难时非常有用. 关于这种语法的更多内容, 请阅读这里
分享到:
相关推荐
个关于freemarker+webwork+spring+ibatis的demo文档
转载的文章,利用freemarker生成word,可适用于(有附表的或无附表)word模板填充动态数据。
6. **模板文档**:插件可能还提供内置的Freemarker文档链接,便于查阅官方文档,学习和理解更多关于Freemarker的用法。 7. **整合开发环境**:由于Freemarker-IDE插件是为Eclipse设计的,所以它能够无缝集成到...
`LICENSE.txt`文件是关于Freemarker的开源许可证,通常为Apache License 2.0,它规定了软件的使用、分发和修改规则。 关于Freemarker的知识点,我们可以讨论以下几个方面: 1. **模板语言**:Freemarker使用简单的...
这个压缩包包含了一些关于Freemarker的重要资源,下面我们将详细探讨这些内容。 首先,`FreeMarker_Manual_zh_CN.pdf`是Freemarker的中文API手册,这是学习和使用Freemarker的关键文档。通过这份手册,你可以了解到...
FreeMarker是一个强大的、开源的模板引擎,主要用于生成动态HTML、XML或其他格式的...在阅读《FreeMarkerDemo》项目中的代码,你会更深入地理解这些概念,并可能发现更多关于FreeMarker操作字符串的技巧和最佳实践。
在Java开发中,利用Freemarker生成Word文档是一种常见的需求,尤其是在处理动态数据和报告生成时。以下将详细介绍如何使用Freemarker和Java生成Word文档。 首先,理解Freemarker的工作原理:Freemarker是一个基于...
此标题清晰地表明了该教程的目标是提供关于FreeMarker全面的教学指导,适合所有希望深入学习FreeMarker的开发者。通过“手把手”这一表述强调了教程的实践性和易学性,旨在帮助读者通过具体实例来掌握FreeMarker的...
以下是关于FreeMarker的重要知识点: **1. 模板语言** FreeMarker使用一种简单的、基于文本的模板语言,它允许开发者通过定义变量和表达式来处理数据模型。模板语言由指令(directives)和表达式(expressions)...
在这个"Freemarker:我自己学习freemarker时写的关于freemarker的一些东西"项目中,我们可以期待看到一些关于学习Freemarker的基础知识、实例和经验分享。 1. **Freemarker基本概念** - **模板语言**: Freemarker...
在Eclipse的"首选项"或"首选项设置"中,你应该能看到关于Freemarker的新选项或配置。 该插件`hudson.freemarker_ide_0.9.14`可能是一个特定版本的Freemarker IDE插件,由Hudson项目(现在称为Jenkins)维护,用于...
在本压缩包中,你将找到关于Freemarker的最新完整资源,包括文档、安装包以及操作手册,以下是对这些内容的详细解释: 1. **freemarker-2.3.23.jar**:这是Freemarker的核心库文件,包含了所有Freemarker运行所需的...
这个压缩包中的内容很可能包含了一系列关于Freemarker的详细注释,旨在帮助初学者理解其工作原理和使用方法。让我们深入探讨一下Freemarker在Java模板技术中的重要性和相关知识点。 1. **Freemarker的基本概念** -...
在这个压缩包中,包含了关于FreeMarker的多个学习资源,旨在帮助用户深入理解和掌握这个模板语言。 1. **FreeMarker的基本概念**: FreeMarker是一个基于模板的Java库,它将数据模型与HTML或其他格式的模板结合,...
在本教程中,你将学习到关于Freemarker的基本概念和核心功能。`Freemarker2.3.19.jar`是Freemarker库的一个版本,包含了所有你需要运行和操作Freemarker模板的类和方法。这个JAR文件可以添加到Java项目中,以便在...
以下是关于FreeMarker、Servlet和Spring的相关知识点,以及可能在Demo中涉及的内容: 1. **FreeMarker**: - **基本概念**:FreeMarker是一个Java库,它根据模板(.ftl文件)和数据模型生成文本输出。它与业务逻辑...
以下是一些关于Freemarker的关键知识点: 1. **模板语言**:Freemarker使用简单的文本文件作为模板,其中包含控制结构(如条件语句和循环)以及变量引用。这些模板语言元素是用特定的语法表示的,比如`<#if>`、`...
在中文文档中,你将找到关于FreeMarker的配置、模板语法、指令、内置对象和方法、变量作用域、宏、模板继承、国际化支持等方面的内容。学习如何配置FreeMarker以适应项目需求,理解模板语言的各个元素,以及如何与...
Word从2003开始支持XML格式,用XML来做就很简单了。 大致的思路是先用office2003或者2007编辑好word的样式,然后另存为xml,将xml...关于FreeMarker模板编辑说明在我的资源中有中文文档,需要的朋友可以去下载。