`

常用语法

阅读更多
常用语法
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;
    }
}

==========================================================

ftl page code:


sun
Tag标签: FreeMarker
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> 1<#escape x as x?if_exists?html>
 2    
 3    用户名:${user?if_exists.userName}<br>
 4
 5    姓名:${'name'}<br>
 6   
 7   <#escape xx as user?if_exists.userInfo?if_exists[xx]>    
 8         
 9       <#noescape>
10        性别:<#if user?if_exists.userInfo?if_exists.gendar?if_exists.i18n?exists>
11                        ${action.getText(user.userInfo.gendar.i18n)}
12                    </#if>
13        </#noescape>
14         
15        身份证:${'idCardNo'}<br>
16          
17        联系电话:${'telephone'}<br>
18          
19        手机:${'mobile'}<br>
20          
21         邮箱:${'email'}<br>
22          
23        地址:${'address'}<br>
24          
25        个人简介:${'resume'}<br>
26
27    </#escape>
28
29</#escape>
Java Code:
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> 1class User 
 2{
 3    private String name;
 4    private String userName;
 5    private UserInfo userInfo;
 6
 7    //getter and setter method 
 8    //
 9}

10
11class UserInfo 
12{
13    private String idCardNo;
14    private String telephone;
15    private String mobile;
16    private String email;
17    private String address;
18    private String resume;
19    private Sex gendar;
20    //getter and setter method 
21    //
22}

23
24public enum Sex implements EnumI18n{    
25    MALE(0"el.enum.human.status.male"),
26    FEMALE(1"el.enum.human.status.female"),
27
28    private String i18n;
29    
30    Sex( String i18n) {
31        this.i18n = i18n;
32    }

33    
34    public String getI18n() {
35        return this.i18n;
36    }

37}
==============================================================

<#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>


分享到:
评论

相关推荐

    高考英语常用语法图解

    【高考英语常用语法图解】主要涵盖了英语语法中名词这一重要概念,旨在帮助高考生更好地理解和掌握英语名词的使用规则。下面将详细阐述名词的种类、数的变化以及一些不规则名词复数形式。 首先,名词根据性质可分为...

    sqlserver2005的常用语法

    以下是一些关于SQL Server 2005常用语法的关键知识点: 1. **数据库安装**:安装SQL Server 2005涉及一系列步骤,包括选择安装类型(如企业版、标准版等)、配置服务器实例、设置网络协议和身份验证模式,以及安装...

    Servlet常用语法Demo

    本实例"Servlet常用语法Demo"旨在帮助初学者理解并掌握Servlet的基本用法和常见应用场景。 1. **Servlet生命周期** Servlet的生命周期包括加载、初始化、服务、销毁四个阶段。当服务器启动或第一次接收到对Servlet...

    C#常用语法简介

    C#常用语法简介 ,包括基本的语法简介,适合初学者学习。

    英语常用语法图解DOC版

    ### 英语常用语法图解知识点详解 #### 一、名词 名词是英语语法中一个非常重要的组成部分,根据其特点可以分为不同的类型,并且在不同的语境中有不同的使用方式。 ##### 1. 名词的种类 - **专有名词**:指特定的...

    PostgreSQL常用语法收集.sql

    PostgreSQL常用语法收集,Postgresql 当中有四种方式获取当前时间。时间格式化,时间间隔计算等等

    正则表达式常用语法

    正则表达式入门常用的语法,包括一些常用的元字符,字符组的定义,环视的简单介绍比较小,已经可以解决大部分正则问题

    cmd 命令行 常用语法

    cmd 命令行 常用语法 cmd 命令行 常用语法 cmd 命令行 常用语法

    Redis常用语法命令及使用示例详解

    ### Redis常用语法命令及使用示例详解 #### 一、Redis简介 Redis是一个开源的、内存中的数据结构存储系统,以其高性能和丰富的功能而著称。它可以被当作数据库、缓存以及消息中间件来使用。Redis支持多种数据类型...

    MySQL常用语法与操作语句实例

    MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用语法与操作语句实例MySQL+PHP常用...

    vsto操作excel的常用语法

    VSTO 操作 Excel 的常用语法 VSTO(Visual Studio Tools for Office)是一种基于 Microsoft Office 应用程序的开发工具,允许开发者使用 Visual Studio 创建 Office 解决方案。下面将对 VSTO 操作 Excel 的常用语法...

    SqlServer常用语法[参考].pdf

    SqlServer常用语法 Sql Server是一种关系型数据库管理系统,具有强大的数据存储和管理功能。为了更好地使用SqlServer,需要掌握一些基本的语法和约束。 一、约束种类 在SqlServer中,约束是一种限制或规则,用于...

    MySQL5.1常用语法汇总

    以下是一些MySQL5.1常用语法的详细说明: 1. **数据库操作**: - `SHOW DATABASES;`:用于列出服务器上所有的数据库。 - `CREATE DATABASE name;`:创建一个新的数据库。 - `USE databasename;`:选择并切换到...

    职称英语常用语法详解

    【职称英语常用语法详解】 在准备职称外语考试的过程中,了解并掌握英语的语法规则是至关重要的。以下是关于英语语法的一些核心知识点: 1. **词类**:英语中的词类包括名词、动词、形容词、副词、介词、连接词和...

    英语四级常用语法归类大全.doc

    英语四级常用语法归类大全 本资源的标题是“英语四级常用语法归类大全”,描述是同名的,标签为空,部分内容展示了英语四级考试 CET4 的常用语法归类大全,包括时态、非谓语动词等。 时态是英语语法中非常重要的一...

    Delphi常用语法和控件用法

    以下是一些Delphi的常用语法和控件用法的详细说明: 1. **注解**:在Delphi中,你可以使用三种不同的注解方式: - `{}` 用于大段注释,注释直到行尾。 - `(* ... *)` 用于多行注释,可以嵌套。 - `//` 开始单行...

    sql常用语法及示例.zip

    在这个“sql常用语法及示例.zip”压缩包中,包含了一个名为“sql常用语法及示例.doc”的文档,它系统地介绍了SQL的基础和高级语法,以及多种函数方法,对于SQL初学者来说,是一份非常实用的学习资料。 首先,让我们...

    mysql和oracle转换常用语法

    mysql转换成oracle时的常用语法说明

    Django常用语法及其在Web开发中的应用

    内容概要:本文档详细介绍了Django框架的常用语法及其应用实例,从项目与应用的创建到模型定义、模型迁移、视图函数与渲染模板的使用、URL路由设置、表单处理、用户认证机制、自定义中间件以及静态文件管理等多个...

Global site tag (gtag.js) - Google Analytics