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=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;
- }
- }
转载于:https://blog.51cto.com/sucre/382687
相关文章:
前百度主任架构师创业,两年融资千万美元,他说AI新药研发将迎来黄金十年...
「AI技术生态论」 人物访谈栏目是CSDN发起的百万人学AI倡议下的重要组成部分。通过对AI生态专家、创业者、行业KOL的访谈,反映其对于行业的思考、未来趋势的判断、技术的实践,以及成长的经历。2020年,CSDN将对1000人物进行访谈,形…
Linux环境安装卸载JDK以及安装Tomcat和发布Java的web程序
Linux环境:CentOS7.2 一.安装JDK 安装好的CentOS会自带OpenJdk,最好还是先卸载系统自带的JDK,然后自己重新去Oracle网站下载最新的JDK安装。 1.卸载系统自带的JDK 查看java信息 # java -version 查看JDK # rpm -qa | grep java 或者 还…
(转)详解css3弹性盒模型(Flexbox)
今天刚学了css3的弹性盒模型,这是一个可以让你告别浮动、完美实现垂直水平居中的新特性。 Flexbox是布局模块,而不是一个简单的属性,它包含父元素和子元素的属性。 Flexbox布局的主体思想是似的元素可以改变大小以适应可用空间,当…
Java开发环境的搭建以及使用eclipse创建项目
一、Java 开发环境的搭建 这里主要说windows环境下怎么配置Java环境。如果是Linux环境参考本博客另一篇文章即可: Linux环境安装卸载JDK 1.首先安装JDK java的SDK简称JDK。 去官网下载最新的JDK即可: http://www.oracle.com/technetwork/java/javase…
MMIT冠军方案 | 用于行为识别的时间交错网络,商汤公开视频理解代码库
作者 | 商汤出品 | AI科技大本营(ID:rgznai100)本文主要介绍三个部分:一个高效的SOTA视频特征提取网络TIN,发表于AAAI2020ICCV19 MMIT多标签视频理解竞赛冠军方案,基于TIN和SlowFast一个基于PyTorch,包含大…

MySQL的主从服务器配置
MySQL的主从服务器配置常见开源数据库有:MySQL,PostgreSQL,SQLite等,商业性质的:Oracle,Sql Server,DB2,Sybase,Infomix其中,Oracle的版本有Oracle 11g,Oracl…

Anaconda中安装Orange3脚本-完整版
2019独角兽企业重金招聘Python工程师标准>>> #Anaconda中安装Orange3脚本,完整版。包括插件的安装,在脚本中一次完成。 sudo apt-get update sudo apt-get -y install git python-pip python-virtualenv python-qt4-dev python3-pyqt4 libqt…
使用eclipse创建Struts2项目
eclipse版本: Kepler Service Release 1 http://www.eclipse.org/downloads/ struts版本:2.3.16 http://struts.apache.org/ 1.新建web项目 打开Eclipse,新建一个web项目"Struts2" 项目名字 勾选 web.xml选项 建好的…

8、进程通信-匿名管道
匿名管道 一个单向,未命名的管道,通常用来在一个父进程和一个子进程间传输数据。只能实现本地机器上两个进程间的通信,而不能实现跨网络的通信。 BOOL CreatePipe( PHANDLE hReadPipe, // read handle PHANDLE hWriteP…
Enhanced-RCNN: 一种高效的比较句子相似性的方法 |WWW 2020
作者 | 彭爽出品 | AI科技大本营(ID:rgznai100)国际顶级会议WWW2020将于4月20日至24日举行。始于1994年的WWW会议,主要讨论有关Web的发展,其相关技术的标准化以及这些技术对社会和文化的影响,每年有大批的学者、研究人…

直接可以拿去用的正则验证表达式
直接可以拿去用的正则验证表达式为了方便自己也方便初学的学弟们,自己总结了网上的众多正则验证式,现分享给大家,可以直接拿去用。一、校验数字的1 数字:^[0-9]*$2 n位的数字:^\d{n}$3 至少n位的数字:^\d{n…
家庭局域网开启AP隔离利用无线路由器互连
一开始可以上网,可以ping网关192.168.1.1,但是几台电脑之间就是不能互ping。 其实,真实的原因就是没有开启无线路由器的AP隔离。 在浏览器中输入192.168.1.1进入路由搜索一般用户名密码都是admin,具体请参见自己路由的说明书 操…
通过 Python 代码实现时间序列数据的统计学预测模型
来源 | DeepHub IMBA封图 | CSDN 付费下载于视觉中国 在本篇中,我们将展示使用 Python 统计学模型进行时间序列数据分析。 目标是:根据两年以上的每日广告支出历史数据,提前预测两个月的广告支出金额。原始数据:2017-01-01 到 201…

神色洋溢的 域名背后的故事
前短时间,我刚申请一个域名,好的顶级域名都被被人一拥而上的都强去了,我只好找那些申请好的用户买呀,这叫炒作,就是这样的抄起来的。你说平常一个也就100左右就搞定,可是现在要是到那票手里,那就…

Rust语言开发基础(六)基础语法
2019独角兽企业重金招聘Python工程师标准>>> 一、变量的定义和使用 其它常见的编程语言对变量的定义通常是通过声明类型和使用关键new来创建一个变量,但Rust不是,Rust使用关键字let。 1. 变量绑定通过let实现 fn main() { let x 5; } 2. 变量…
400 多行代码!超详细 Rasa 中文聊天机器人开发指南 | 原力计划
作者 | 无名之辈FTER责编 | 夕颜出品 | 程序人生(ID:coder_life)本文翻译自Rasa官方文档,并融合了自己的理解和项目实战,同时对文档中涉及到的技术点进行了一定程度的扩展,目的是为了更好的理解Rasa工作机制…
Linux配置SSH无密码登陆
可以使用“公钥私钥"认证的方式来进行ssh登录。 所谓 "公钥私钥"认证方式,就是首先在客户机上创建一对公钥和私钥,公钥文件:~/.ssh/id_rsa.pub; 私钥文件:~/.ssh/id_rsa 然后把公钥文件放到目标服务器…
Linux进程浏览器htop安装与使用
htop 是一个 Linux 下的交互式的进程浏览器,可以用来替换Linux下的top命令。当前具有按树状方式来查看进程,支持颜色主题,可以定制等特性。其实htop是top的加强版,增加了很多功能。 官网 http://hisham.hm/htop/ 下载地址http:/…
什么?神经网络还能求解高级数学方程?
来源 | 数据派 THU封图 | CSDN 付费下载于视觉中国 Facebook AI建立了第一个可以使用符号推理解决高级数学方程的AI系统。通过开发一种将复杂数学表达式表示为一种语言的新方法,然后将解决方案视为序列到序列的神经网络的翻译问题,我们构建了一个在解决积…

***和******
网络是一把双刃剑,它在人类社会的发展中起着越来越重要作用,但同时,网络自身的安全问题也像挥之不去的阴影时刻笼罩在人们心头。据不完全统计,全世界平均每 20秒钟就发生一起******事件,互联网上大约有20万个***网站可…
Linux监控工具dstat
dstat是一个用来替换 vmstat,iostat netstat,nfsstat和ifstat这些命令的工具, 是一个全能系统信息统计工具. 与sysstat相比, dstat拥有一个彩色的界面, 在手动观察性能状况时, 数据比较显眼容易观察; 而且dstat支持即时刷新, 譬如输入dstat 3, 即每三秒收集一次, 但最新的数据都…

9月16号晚上,Asuka有一场关于Windows 7组策略的Webcast,欢迎兄弟们来捧场
之所以选题在组策略之一块,是因为Windows 7和2008 R2对于组策略有了很大的功能上的增强,但是很多IT人员都无法意识或者去重视这一块内容,所以我将从下面这3个角度去介绍这些更新。如果您正好有时间,那不妨来技术交流一番:)直播进入…

腾讯天衍实验室联合微众银行研发医疗联邦学习 AI利器让脑卒中预测准确率达80%
近几年,医疗行业正在经历一场数字化转型,这场基于大数据和AI技术的变革几乎改变了整个行业的方方面面,将“信息就是力量”这句箴言体现的淋漓尽致,人们对人工智能寄以厚望,希望它能真正深入临床一线,帮助医…

JavaSript模块化 AMD CMD 详解.....
模块化是指在解决某一个复杂问题或者一系列的杂糅问题时,依照一种分类的思维把问题进行系统性的分解以之处理。模块化是一种处理复杂系统分解为代码结构更合理,可维护性更高的可管理的模块的方式。可以想象一个巨大的系统代码,被整合优化分割…
在Eclipse中使用Maven构建Spring项目
最新版的Spring需要使用Maven构建,本文讲述怎么在Eclipse构建Maven项目,以配置Spring项目为例。 maven简单介绍 maven是构建工具,也是构建管理工具。ant只是构建工具,因为不支持生成站点功能,只有预处理,编…

Go 语言官网全新改版
2019独角兽企业重金招聘Python工程师标准>>> 前两天发现 Go 语言官网改版了,布局由原来的左中右变成了上中下结构,主色调没有变,整体依然保持简洁的风格。在首页添加了一个叫 Playground 的模块,它可以编译、运行你输入…
就在今晚 | 港科大李世玮教授问诊未来,开辟大湾区新航路
阳春三月,万象更新,2020年注定是不平凡的一年!有激荡就会遇见变革,有挑战就会迎来机遇。今天总会过去,未来将会怎样?香港科大商学院内地办事处重磅推出全新升级的《袁老师访谈录》全新系列【问诊未来院长系…

NLP(Natural Language Processing)
https://github.com/kjw0612/awesome-rnn#natural-language-processing 通常有: (1)Object Recognition (2)Visual Tracking (3)Image Generation (4)Video Analysis NLP: (1)Language Modeling (2)Speech Recognition…
Linux环境编程
1.__sync_fetch_and_add和__sync_bool_compare_and_swap gcc从4.1.2提供了__sync_*系列的built-in函数,用于提供加减和逻辑运算的原子操作。 其声明如下: type __sync_fetch_and_add (type *ptr, type value, ...) type __sync_fetch_and_sub (type *p…
AI新基建如何构建?浪潮给出了一个答案
作者 | Just出品 | AI科技大本营(ID:rgznai100)伴随生产力升级,社会基础设施也正在发生变化。而智慧时代的新型基础设施,要能够对外提供各种算力服务、数据服务和AI服务。浪潮认为,其核心是计算力的生产中心。因此&…