string(当和一个日期值一起使用)
这个内置标签用指定的格式把日期转换成字符串,(把默认的格式用FreeMarker的ate_format,time_format和datetime_format设置指定对你有好处,那样的话你就不需要这个标签了。
格式可以是一个预定义的,你也可以明确指定格式。
预定义的格式是:short,medium,long和full。定义了结果字符串的长度。例如,如果locale是US_EN,时区是US.PACIFIC,那么:
${openingTime?string.short}
${openingTime?string.medium}
${openingTime?string.long}
${openingTime?string.full}
${nextDiscountDay?string.short}
${nextDiscountDay?string.medium}
${nextDiscountDay?string.long}
${nextDiscountDay?string.full}
${lastUpdated?string.short}
${lastUpdated?string.medium}
${lastUpdated?string.long}
${lastUpdated?string.full}
输出类似这样:
12:45 PM
12:45:09 PM
12:45:09 PM CEST
12:45:09 PM CEST
4/20/07
Apr 20, 2007
April 20, 2007
Friday, April 20, 2007
4/20/07 12:45 PM
Apr 20, 2007 12:45:09 PM
April 20, 2007 12:45:09 PM CEST
Friday, April 20, 2007 12:45:09 PM CEST
short,medium.long和full准确的意思依赖于当前locale(语言),此外,这是你运行FreeMarker的java实现平台所指定的,而不是FreeMarker。
对于即包含日期和时间的日期值,你可以单独的指定日期和时间部分的长度。
${lastUpdated?string.short_long} <#-- short date, long time -->
${lastUpdated?string.medium_short} <#-- medium date, short time -->
将会输出:
4/8/03 9:24:44 PM PDT
Apr 8, 2003 9:24 PM
注意:string.short跟?string.short_short是一样的,?string.medium和string.medium_medium一样……
警告:
不幸的是,由于java平台的限制。当你在Data Model中存有日期值的时候,FreeMarker不能决定该变量只存储日期部分或者时间部分再或者日期和时间。这种情况下当你 像${lastUpdated?string.short}或者简单的${lastUpdated}这样写的时候,FreeMarker不知道如何显示日 期。这样它会停下来,并且报错。为了防止这样,你可以使用?date,?time和?datetime内置标签来帮助FreeMarker。举 例:${lastUpdated?datetime?string.short}.询问程序员某个日期变量是否存在这个问题,或者一直使 用?date,?time和?datetime。
你可以使用?string(格式)明确指定格式,代替预定义格式。格式使用java日期格式语法例如:
${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)
注意:
不像预定义格式,你不需要在指定的格式上使用?date,?time和?datetime,因为你指定的格式告诉FreeMarKer显示日期的哪 部分。无论如何,FreeMarker都会相信你,so you can show "noise" if you display parts that are actually not stored in the variable.例如:${openingTime?string("yyyy-mm-dd hh:mm:ss a")},openingTime只存储了时间。将会显示1790-01-01 09:24:44 PM.
格式也可以是short,medium……"short_medium"等等。这样跟你用"."使用预定义的格式是一样的:someDate?string("short")和someDate?string.short是相当的。
date,time,datetime
这些标签可以用来指定日期变量中的哪些部分被使用。
date:只使用年、月、日
time:只使用时、分、秒和毫秒部分
datetime:日期和时间两部分都被使用
理想情况下,你不需要使用它们。不幸的是,由于java平台的技术限制。FreeMarker有的时候不能找到日期变量使用的部分(例如:只有年月 日,或者只有时分秒,或者两者)询问程序员那个变量存在这个问题。如果FreeMarker需要执行一个需要这个变量的操作--就像把日期作为字符显示 --但是它不知道使用那些部分,它会停下来报错。这就是你必须使用这些标签的情况。例如:假定openingTime就是这样一个问题变量:
<#assign x = openingTime> <#-- no problem can occur here -->
${openingTime?time} <#-- without ?time it would fail -->
<#-- For the sake of better understanding, consider this: -->
<#assign openingTime = openingTime?time>
${openingTime} <#-- this will work now -->
另一种用法:切短日期。例如:
Last updated: ${lastUpdated} <#-- assume that lastUpdated is a date-time value -->
Last updated date: ${lastUpdated?date}
Last updated time: ${lastUpdated?time}
将显示:
Last updated: 04/25/2003 08:00:54 PM
Last updated date: 04/25/2003
Last updated time: 08:00:54 PM
分享到:
相关推荐
除了内置函数,FreeMarker还支持通过`<#function>`标签创建自定义函数,以便扩展其功能。 了解并熟练使用这些内置函数,能够显著提升在FreeMarker模板中的开发效率,使模板代码更加简洁和高效。在实际应用中,可以...
本篇文章将深入探讨FreeMarker内置的几个处理方法及其应用场景。 1. **变量表达式**: FreeMarker中的基础元素是变量表达式 `${}`,它用于在模板中显示变量的值。例如,`${name}` 会输出与`name`关联的数据模型中...
本文将深入探讨FreeMarker的标签、指令、插值规则以及表达式。 首先,FreeMarker 模板文件由四个主要部分组成: 1. 文本:这部分内容会被直接输出。 2. 注释:以`<#-- ... -->`形式存在,不会被输出到最终文档中。...
4. 为Web准备:内置处理Web相关任务的结构,如HTML转义,可与Model2 Web应用框架集成,如Struts,作为JSP的替代品,支持JSP标签库,实现MVC模式下的可视化设计与应用程序逻辑分离。 5. 国际化和本地化支持:包括字符...
使用Freemarker内置标签** - 尽量使用Freemarker自带的标签以提高性能。 **10. 特殊指令** - `r` 原样输出。 - `?` 引出内置指令。 - `@` 用户自定义标签。 **11. 特殊操作符** - `!`: 默认值操作符。 - `?...
5. **国际化(i18n)支持**:FreeMarker支持多语言环境,可以通过`<#t>`标签进行日期和时间的本地化处理,`<#lt>`标签进行文本的本地化。 6. **安全机制**:FreeMarker有防止跨站脚本(XSS)攻击的安全特性,可以...
5. **日期和数字格式化**:FreeMarker 提供了内置的方法来格式化日期和数字,如 `${date?string("yyyy-MM-dd")}` 可以将日期对象转换为指定格式的字符串。 6. **宏**:宏是可重用的模板片段,类似于函数。通过`...
FreeMarker定义了三种类型的FTL指令:开始标签、结束标签和空标签。开始标签格式为,结束标签格式为,空标签格式为。如果使用的指令是用户自定义而不是内置指令,应将#符号改为@符号。 在使用FTL标签时,应该遵循...
8. **日期和数字格式化**:FreeMarker允许对日期和数字进行格式化,如 `${date?string("yyyy-MM-dd HH:mm:ss")}`。 9. **国际化(i18n)支持**:通过`<#assign>`指令和`<#t>`标签,FreeMarker可以方便地处理多语言...
需要注意的是,如果指令是用户自定义的而非FreeMarker内置,则使用`@`代替`#`。例如:`<@customDirective param/>`。 当使用FTL指令时,必须遵循正确的嵌套规则,如同XML标签一样,不能出现交叉嵌套的情况。此外,...
- **日期值**:同样根据默认格式输出,也可以通过内置函数进行格式化。 - **布尔值**:按照默认格式输出,也可以使用内置函数进行格式化。 ##### 数字格式化插值 数字格式化插值允许开发者指定特定的格式,例如: -...
3. **丰富的内置对象**:FreeMarker提供了一系列内置对象,如日期处理、字符串操作等,使得开发者无需编写额外的代码即可实现复杂的功能。 4. **自定义标签支持**:除了内置的对象外,FreeMarker还允许用户自定义...
8. **内置函数和方法**:Freemarker内置了如`default`、`escape`、`size`等函数,以及对象的`?`操作,如`?exists`、`?non_null`等。 9. **错误和异常处理**:通过`<#try>`、`<#catch>`进行错误捕获和处理,确保模板...
7. **日期和数字格式化**:FreeMarker支持对日期、时间及数字的格式化,可以按照特定的格式展示数据,如`<#formatDate value="yyyy-MM-dd" />`。 8. **缓存机制**:FreeMarker有内置的缓存系统,可以缓存编译后的...
- **本地化敏感**: 数字、日期和时间格式都支持本地化处理。 - **多语言支持**: 同一模板可以适应多种语言。 - **强大的XML处理能力**: - **递归遍历**: 使用`<#recurse>`和`<#visit>`指令递归遍历XML树。 - **...
Freemarker支持多语言,可以通过`<#t>`和`<@i18n>`标签进行国际化资源的访问。 ### 9. 配置管理 Freemarker允许通过`freemarker.template.Configuration`类进行配置,如设置模板目录、缓存策略等。 总结来说,...
Freemarker内建了一系列便捷的功能,例如日期时间格式化、字符串操作、算术运算、逻辑判断等。这使得开发者无需额外的库就能处理常见的数据处理任务,简化了开发流程。 5. **宏定义**: 宏类似于JSP的自定义标签...
7. **国际化(I18N)**:Freemarker支持国际化,可以通过`<#t>`标签和`<#lt>`标签进行日期、时间的格式化,以及通过`<#assign>`或`<#function>`处理多语言资源。 8. **缓存(Caching)**:为了提高性能,Freemarker可以...
FreeMarker的灵活性体现在它支持多种数据类型和内置函数,比如日期时间处理、字符串操作、条件语句、循环结构等。它还可以自定义标签库(Tag Libraries)来扩展其功能,与现有的Java库无缝集成。 在实际应用中,...
需要注意的是,在某些情况下,如果指令是由用户自定义而非FreeMarker内置的,则前缀`#`应该替换为`@`。此外,使用FTL标签时应当遵循正确的嵌套规则,这一点与XML标签的使用方式相同。如果使用了不存在的指令,...