常用语法
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=ture />
${foo?string("yes","no")} <#-- yes -->
2.逻辑判断
a:
<#if condition>...
<#elseif condition2>...
<#elseif condition3>......
<#else>...
其中空值判断可以写成<#if book.name?? >
</#if>
b:
<#switch value>
<#case refValue1>
...
<#break>
<#case refValue2>
...
<#break>
...
<#case refValueN>
...
<#break>
<#default>
...
</#switch>
3.循环读取
<#list sequence as item>
...
</#list>
空值判断<#if bookList?size = 0></#list>
e.g.
<#list employees as e>
${e_index}. ${e.name}
</#list>
输出:
1. Readonly
2. Robbin
4.FreeMarker
3 宏/模板
宏Macro
宏是在模板中使用macro指令定义
l.1 基本用法
宏是和某个变量关联的模板片断,以便在模板中通过用户定义指令使用该变量,下面是一个例子:
<#macro greet>
<font size="+2">Hello Joe!</font>
</#macro>
调用宏时,与使用FreeMarker的其他指令类似,
只是使用@替代FTL标记中的#。
<@greet></@greet>
<#--<@greet/>-->
在macro指令中可以在宏变量之后定义参数,如:
<#macro greet person>
<font size="+2">Hello ${person}!</font>
</#macro>
可以这样使用这个宏变量:
<@greet person="Fred"/>
但是下面的代码具有不同的意思:
<@greet person=Fred/>
这意味着将Fred变量的值传给person参数,该值不仅是字符串,还可以是其它类型,甚至是复杂的表达式。
宏可以有多参数,下面是一个例子:
<#macro greet person color>
<font size="+2" color="${color}">Hello ${person}!</font>
</#macro>
可以这样使用该宏变量,其中参数的次序是无关的:
<@greet person="Fred" color="black"/>
可以在定义参数时指定缺省值,否则,在调用宏的时候,必须对所有参数赋值:
<#macro greet person color="black">
<font size="+2" color="${color}">Hello ${person}!</font>
</#macro>
注意:宏的参数是局部变量,只能在宏定义中有效。
在宏里嵌套内容
FreeMarker的宏可以有嵌套内容,
<#nested>指令会执行宏调用指令开始和结束标记之间的模板片断,举一个简单的例子:
<#macro border>
<table border=4 cellspacing=0 cellpadding=4><tr><td>
<#nested>
</tr></td></table>
</#macro>
执行宏调用:
<@border>The bordered text</@border>
输出结果:
<table border=4 cellspacing=0 cellpadding=4>
<tr><td>
The bordered text
</tr></td>
</table>
<#nested>指令可以被多次调用,每次都会执行相同的内容。
<#macro do_thrice>
<#nested>
<#nested>
<#nested>
</#macro>
<@do_thrice>
Anything.
</@do_thrice>
FMPP 输出结果:
Anything.
Anything.
Anything.
嵌套内容可以是有效的FTL,下面是一个有些复杂的例子,我们将上面三个宏组合起来:
<@border>
<ul>
<@do_thrice>
<li><@greet person="Joe"/>
</@do_thrice>
</ul>
</@border>
输出结果:
<table border=4 cellspacing=0 cellpadding=4><tr><td>
<ul>
<li><font size="+2">Hello Joe!</font>
<li><font size="+2">Hello Joe!</font>
<li><font size="+2">Hello Joe!</font>
</ul>
</tr></td></table>
宏定义中的局部变量对嵌套内容是不可见的,例如:
<#macro repeat count>
<#local y = "test">
<#list 1..count as x>
${y} ${count}/${x}: <#nested>
</#list>
</#macro>
<@repeat count=3>${y?default("?")} ${x?default("?")} ${count?default("?")}</@repeat>
输出结果:
test 3/1: ? ? ?
test 3/2: ? ? ?
test 3/3: ? ? ?
在宏定义中使用循环变量
nestted指令也可以有循环变量(循环变量的含义见下节),调用宏的时候在宏指令的参数后面依次列出循环变量的名字,格式如下:
<@ macro_name paramter list; loop variable list[,]>
例如:
<#macro repeat count>
<#list 1..count as x>
<#nested x, x/2, x==count>
</#list>
</#macro>
<@repeat count=4 ; c, halfc, last>
${c}. ${halfc}<#if last> Last!</#if>
</@repeat>
这里count是宏的参数,c, halfc,last则为循环变量,输出结果:
1. 0.5
2. 1
3. 1.5
4. 2 Last!
循环变量和宏标记指定的不同不会有问题,如果调用时少指定了循环变量,那么多余的值不可见。调用时多指定了循环变量,多余的循环变量
不会被创建:
<@repeat count=4 ; c, halfc, last>
${c}. ${halfc}<#if last> Last!</#if>
</@repeat>
<@repeat count=4 ; c, halfc>
${c}. ${halfc}
</@repeat>
<@repeat count=4>
Just repeat it...
</@repeat>
在模板中定义变量
在模板中定义的变量有三种类型:
plain变量:可以在模板的任何地方访问,包括使用include指令插入的模板,使用assign指令创建和替换。
局部变量:在宏定义体中有效,使用local指令创建和替换。
循环变量:只能存在于指令的嵌套内容,由指令(如list)自动创建;宏的参数是局部变量,而不是循环变量
局部变量隐藏(而不是覆盖)同名的plain变量;循环变量隐藏同名的局部变量和plain变量,下面是一个例子:
<#assign x = "plain">
${x} <#-- we see the plain var. here -->
<@test/>
6. ${x} <#-- the value of plain var. was not changed -->
<#list ["loop"] as x>
7. ${x} <#-- now the loop var. hides the plain var. -->
<#assign x = "plain2"> <#-- replace the plain var, hiding does not mater here -->
8. ${x} <#-- it still hides the plain var. -->
</#list>
9. ${x} <#-- the new value of plain var. -->
<#macro test>
2. ${x} <#-- we still see the plain var. here -->
<#local x = "local">
3. ${x} <#-- now the local var. hides it -->
<#list ["loop"] as x>
4. ${x} <#-- now the loop var. hides the local var. -->
</#list>
5. ${x} <#-- now we see the local var. again -->
</#macro>
输出结果:
1. plain
2. plain
3. local
4. loop
5. local
6. plain
7. loop
8. loop
9. plain2
内部循环变量隐藏同名的外部循环变量,如:
<#list ["loop 1"] as x>
${x}
<#list ["loop 2"] as x>
${x}
<#list ["loop 3"] as x>
${x}
</#list>
${x}
</#list>
${x}
</#list>
输出结果:
loop 1
loop 2
loop 3
loop 2
loop 1
模板中的变量会隐藏(而不是覆盖)数据模型中同名变量,如果需要访问数据模型中的同名变量,使用特殊变量global,下面的例子假设数据
模型中的user的值是Big Joe:
<#assign user = "Joe Hider">
${user} <#-- prints: Joe Hider -->
${.globals.user} <#-- prints: Big Joe -->
名字空间
通常情况,只使用一个名字空间,称为主名字空间,但为了创建可重用的宏、变换器或其它变量的集合(通常称库),必须使用多名字空间,
其目的是防止同名冲突
创建库
下面是一个创建库的例子(假设保存在lib/my_test.ftl中):
<#macro copyright date>
<p>Copyright (C) ${date} Julia Smith. All rights reserved.
<br>Email: ${mail}</p>
</#macro>
<#assign mail = "jsmith@acme.com">
使用import指令导入库到模板中,Freemarker会为导入的库创建新的名字空间,并可以通过import指令中指定的散列变量访问库中的变量:
<#import "/lib/my_test.ftl" as my>
<#assign mail="fred@acme.com">
<@my.copyright date="1999-2002"/>
${my.mail}
${mail}
输出结果:
<p>Copyright (C) 1999-2002 Julia Smith. All rights reserved.
<br>Email: jsmith@acme.com</p>
jsmith@acme.com
fred@acme.com
可以看到例子中使用的两个同名变量并没有冲突,因为它们位于不同的名字空间。还可以使用assign指令在导入的名字空间中创建或替代变量
,下面是一个例子:
<#import "/lib/my_test.ftl" as my>
${my.mail}
<#assign mail="jsmith@other.com" in my>
${my.mail}
输出结果:
jsmith@acme.com
jsmith@other.com
数据模型中的变量任何地方都可见,也包括不同的名字空间,下面是修改的库:
<#macro copyright date>
<p>Copyright (C) ${date} ${user}. All rights reserved.</p>
</#macro>
<#assign mail = "${user}@acme.com">
假设数据模型中的user变量的值是Fred,则下面的代码:
<#import "/lib/my_test.ftl" as my>
<@my.copyright date="1999-2002"/>
${my.mail}
输出结果:
<p>Copyright (C) 1999-2002 Fred. All rights reserved.</p>Fred@acme.com
四.Freemarker与Struts结合
1.输出文件换成以ftl格式的文件
E.G.
<action name="bookActionForm" parameter="method" path="/bookAction" scope="request" type="example.BookAction"
validate="true">
<forward name="list" path="/index.ftl"/>
</action>
2.使用struts,jstl等标签
a.导入à<#global html=JspTaglibs["/WEB-INF/tags/struts-html.tld"]>
或<#assign html=JspTaglibs["/WEB-INF/struts-html.tld"]>
<#assign bean=JspTaglibs["/WEB-INF/struts-bean.tld"]>
<#assign logic=JspTaglibs["/WEB-INF/struts-logic.tld"]>
b.使用à<@bean.page id="request" property="request"/>,
<@html.text property="vo.newsTitle" styleClass="input1"/>
五.用Freemarker生成Html页面
例子:MakeFileManager.java
package example;
import freemarker.template.Configuration;
import java.text.SimpleDateFormat;
import java.io.File;
import freemarker.template.DefaultObjectWrapper;
import java.util.Map;
import java.util.HashMap;
import java.io.Writer;
import java.io.OutputStreamWriter;
import java.io.FileOutputStream;
import freemarker.template.TemplateException;
import java.io.IOException;
import freemarker.template.Template;
public class MakeFileManager {
public String make(Book book, BookFtl bookFtl) {
Configuration cfg = new Configuration();//配制
String realPath = bookFtl.getRealPath();
String templatePath = realPath + "/WEB-INF/templates/book";
String cDateStr = "book/" +
new SimpleDateFormat("yyyyMMdd").format(new java.util.
Date());
String filePostfix = ".html";
String path = realPath + "/" + cDateStr;
String fileTimeName = new SimpleDateFormat("yyyyMMddhhmmss").format(new
java.util.Date());
String returnFileName = cDateStr + "/" + fileTimeName + filePostfix;
String fileName = "";
File bookDir = new File(path);
if (bookDir.exists()) {
fileName = path + "/" + fileTimeName + filePostfix;
} else {
bookDir.mkdirs();
fileName = path + "/" + fileTimeName + filePostfix;
}
try {
//设置freemarker的参数
cfg.setNumberFormat("0.##########");//生成html文件时web.xml配制无效
//cfg.setEncoding();
cfg.setDirectoryForTemplateLoading(new File(templatePath));
cfg.setObjectWrapper(new DefaultObjectWrapper());
Template bookTemplate = cfg.getTemplate(bookFtl.getTemplateName());//模板对象
Map root = new HashMap();
root.put("book", book);
root.put("book2",book);
Writer out = new OutputStreamWriter(new FileOutputStream(fileName));
try {
bookTemplate.process(root, out);
} catch (TemplateException e) {
e.printStackTrace();
}
out.flush();
} catch (IOException e) {
e.printStackTrace();
}
return returnFileName;
}
}
==========================================================
Java Code:
==============================================================
<#list listBlogPost as blogPost>
</#list>
如果 listBlogPost 为NULL 会报错.加上?exists(是否存在) 或者?default("")
如果为null时默认为空,例子:
<#if listBlogPost?exists && listBlogPost.size != 0 >
<#if Session["cartList"]?exists>
<#list Session["cartList"] as item>
${pageTitle?default("")}
<#if s?exists>
${s?if_exists}
exists用在逻辑判断,而if_exists用来打印东西时用到,如果存在打印,不存在打印空字符串.
exp1?exists将会被exp1??代替
exp1?if_exists将会被exp1!代替
exp1?default(exp2)将会被exp1!exp2.
===============================================================
近来和朋友做了个项目,Web开发框架用的是webwork(2.2.2)+freemarker!
总结一下,使用feemarker遍历list,map的经验!
1,Action中的定义!
public class CartMaintenanceAction extends BaseAction
{
private Map<String,Item> itemMap;
private List<Item> itemList;
public String input() {
return INPUT;
}
public String find() {
return SUCCESS;
}
public String addItemToCart() {
Map<String,Item> cartMap = new HashMap<String,Item>();;
List<Item> cartList = new ArrayList<Item>();
Item item1 = new Item();
item1.setId(new Long(110));
item1.setName("好好学习");
Item item2 = new Item();
item2.setId(new Long(111));
item2.setName("天天向上");
//切记在webwork自带的freemarker中对Map中Key的定义为String类型(如果你想用${Session["cartMap"][key].name}这样取值的话;如果用${session.getAttribute("cartMap").get(key).getName()}这样取值就可以用其他类型,如Map<Long,Object>),更高片本是否可以用其他类型本人未曾验证。
cartMap.put(item1.getId().toString(),item1);
cartMap.put(item2.getId().toString(),item2);
cartList.add(item1);
cartList.add(item2);
//把list,map放到session中。
ActionContext.getContext().getSession().put("cartMap", cartMap);
ActionContext.getContext().getSession().put("cartList", cartList);
return "add";
}
public List<Item> getItemList() {
return itemList;
}
public void setItemList(List<Item> itemList) {
this.itemList = itemList;
}
public Map<String, Item> getItemMap() {
return itemMap;
}
public void setItemMap(Map<String, Item> itemMap) {
this.itemMap = itemMap;
}
}
2,*.ftl文件。
对List遍历:
<@ww.form action="/order/cartMaintenanceAction!addItemToCart.action" method="post" id="cartFormId">
<#if Session["cartList"]?exists>
<#list Session["cartList"] as item>
//itemList是action中定义的字段。作批量更新使用。
<@ww.hidden name="itemList[${item_index}].id" value="${item.id}"/>
<@ww.textfield name="itemList[${item_index}].name" cssClass="input" value="${item.name}" size="3"/>
</#list>
</#if>
</@ww.form>
对Map遍历:
//Map<String ,Object> Map中的key必为String 型在freemarker 在webwork2.2.2中自己的,更高的版本就不知道可不可能用其他类型,
<@ww.form action="/order/cartMaintenanceAction!addItemToCart.action" method="post" id="cartFormId">
<#if Session["cartMap"]?exists>
<#assign cart = Session["cartMap"]>
<#list cart?keys as itemKey>
<#assign item = cart[itemKey]>
//如果Map中的key是Long类型则用${session.getAttribute("cartMap").get(itemKey).getId}取值。
//itemMap是action中定义的字段。作批量更新使用。
<@ww.hidden name="itemMap[${itemKey}].id" value="${item.id}"/>
<@ww.textfield name="itemMap[${itemKey}].name" cssClass="input" value="${item.name}" size="3"/>
</#list>
</#if>
/@ww.form
<#if dbNamesMap??>
<tr>
<td height="30" align="right" class="f12-white">帐 套:</td>
<td>
<select name="dbName" style="width: 155px">
<#list dbNamesMap?keys as key>
<option value="${key}">${dbNamesMap[key]}</option>
</#list>
</select>
</td>
</tr>
</#if>
<table class="pn-ltable" width="100%" cellspacing="1" cellpadding="0"
border="0">
<thead class="pn-lthead">
<tr>
<#list result.columnNames as name><th> ${name}</th> </#list>
</tr>
</thead>
<tbody class="pn-ltbody">
<#list result.rows as row>
<tr onmouseover="Pn.LTable.lineOver(this);" onmouseout="Pn.LTable.lineOut(this);" onclick="Pn.LTable.lineSelect(this);">
<#list result.columnNames as name>
<#assign item =row[name]>
<#if name_index == 0>
<td>${item}</td>
<#else>
<td>${item?string("##0.00")}</td>
</#if>
</#list>
</tr>
</#list>
</table>
相关推荐
【高考英语常用语法图解】主要涵盖了英语语法中名词这一重要概念,旨在帮助高考生更好地理解和掌握英语名词的使用规则。下面将详细阐述名词的种类、数的变化以及一些不规则名词复数形式。 首先,名词根据性质可分为...
以下是一些关于SQL Server 2005常用语法的关键知识点: 1. **数据库安装**:安装SQL Server 2005涉及一系列步骤,包括选择安装类型(如企业版、标准版等)、配置服务器实例、设置网络协议和身份验证模式,以及安装...
本实例"Servlet常用语法Demo"旨在帮助初学者理解并掌握Servlet的基本用法和常见应用场景。 1. **Servlet生命周期** Servlet的生命周期包括加载、初始化、服务、销毁四个阶段。当服务器启动或第一次接收到对Servlet...
C#常用语法简介 ,包括基本的语法简介,适合初学者学习。
### 英语常用语法图解知识点详解 #### 一、名词 名词是英语语法中一个非常重要的组成部分,根据其特点可以分为不同的类型,并且在不同的语境中有不同的使用方式。 ##### 1. 名词的种类 - **专有名词**:指特定的...
PostgreSQL常用语法收集,Postgresql 当中有四种方式获取当前时间。时间格式化,时间间隔计算等等
正则表达式入门常用的语法,包括一些常用的元字符,字符组的定义,环视的简单介绍比较小,已经可以解决大部分正则问题
cmd 命令行 常用语法 cmd 命令行 常用语法 cmd 命令行 常用语法
### Redis常用语法命令及使用示例详解 #### 一、Redis简介 Redis是一个开源的、内存中的数据结构存储系统,以其高性能和丰富的功能而著称。它可以被当作数据库、缓存以及消息中间件来使用。Redis支持多种数据类型...
MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用...
VSTO 操作 Excel 的常用语法 VSTO(Visual Studio Tools for Office)是一种基于 Microsoft Office 应用程序的开发工具,允许开发者使用 Visual Studio 创建 Office 解决方案。下面将对 VSTO 操作 Excel 的常用语法...
SqlServer常用语法 Sql Server是一种关系型数据库管理系统,具有强大的数据存储和管理功能。为了更好地使用SqlServer,需要掌握一些基本的语法和约束。 一、约束种类 在SqlServer中,约束是一种限制或规则,用于...
以下是一些MySQL5.1常用语法的详细说明: 1. **数据库操作**: - `SHOW DATABASES;`:用于列出服务器上所有的数据库。 - `CREATE DATABASE name;`:创建一个新的数据库。 - `USE databasename;`:选择并切换到...
【职称英语常用语法详解】 在准备职称外语考试的过程中,了解并掌握英语的语法规则是至关重要的。以下是关于英语语法的一些核心知识点: 1. **词类**:英语中的词类包括名词、动词、形容词、副词、介词、连接词和...
英语四级常用语法归类大全 本资源的标题是“英语四级常用语法归类大全”,描述是同名的,标签为空,部分内容展示了英语四级考试 CET4 的常用语法归类大全,包括时态、非谓语动词等。 时态是英语语法中非常重要的一...
以下是一些Delphi的常用语法和控件用法的详细说明: 1. **注解**:在Delphi中,你可以使用三种不同的注解方式: - `{}` 用于大段注释,注释直到行尾。 - `(* ... *)` 用于多行注释,可以嵌套。 - `//` 开始单行...
在这个“sql常用语法及示例.zip”压缩包中,包含了一个名为“sql常用语法及示例.doc”的文档,它系统地介绍了SQL的基础和高级语法,以及多种函数方法,对于SQL初学者来说,是一份非常实用的学习资料。 首先,让我们...
mysql转换成oracle时的常用语法说明
内容概要:本文档详细介绍了Django框架的常用语法及其应用实例,从项目与应用的创建到模型定义、模型迁移、视图函数与渲染模板的使用、URL路由设置、表单处理、用户认证机制、自定义中间件以及静态文件管理等多个...