FreeMarker - 内建函数

简介: FreeMarker - 内建函数

【1】Sequence的内置函数

1.sequence?first 返回sequence的第一个值。

  array: ${cityArray?first}
  list: ${cityList?first}
  set: ${citySet?first}

2.sequence?last 返回sequence的最后一个值。


3.sequence?size 返回sequence的大小。


4.sequence?reverse 将sequence的现有顺序反转,即倒序排序


5.sequence?sort 将sequence中的对象转化为字符串后顺序排序

正    序:<#list cityArray as city>${city},</#list>
倒    序:<#list cityArray?reverse as city>${city},</#list>
升    序:<#list cityArray?sort as city>${city},</#list>
降    序:<#list cityArray?sort?reverse as city>${city},</#list>

6.sequence?sort_by(value) 按sequence中对象的属性value进行排序

7.获取sequence当前元素的索引

<#list sequence as item>
    ${item_index}//获得当前元素索引值
</#list>

8.根据索引获取sequence中的指定元素

array: ${cityArray[0]}
list: ${cityList[0]}
set:  ${citySet[0]}

注意:Sequence不能为null


【2】Hash的内置函数

1.hash?keys 返回hash里的所有key,返回结果为sequence

<#assign mapKeys=cityMap?keys/>
<#list mapKeys as mapKey>
    ${mapKey}
</#list>

2.hash?values 返回hash里的所有value,返回结果为sequence

<#assign mapValues=cityMap?values/>
<#list mapValues as mapValue>
    ${mapValue}
</#list>

3.遍历map元素

map 通过key获取value的方法用[]
<#list cityMap?keys as  key>
   ${key_index} --> ${key} --> ${cityMap[key]}
</#list>

【3】操作字符串内置函数


1.表达式?substring(start,end)从一个字符串中截取子串

start:截取子串开始的索引,start必须大于等于0,小于等于end;

end: 截取子串的长度,end必须大于等于0,小于等于字符串长度,如果省略该参数,默认为字符串长度。

${'EFGHIJKL'?substring(0)}  
${'EFGHIJKL'?substring(0,1)}  

2.cap_first 将字符串中的第一个单词的首字母变为大写。

3.uncap_first将字符串中的第一个单词的首字母变为小写。

4.capitalize将字符串中的所有单词的首字母变为大写。

5.lower_case将字符串转为小写。

6.upper_case将字符串转为大写。

 1. 首个单词的首字母大写: ${"hello world"?cap_first}
 2. 首个单词的首字母小写: ${"Hello World"?uncap_first}
 3. 所有单词首字母大写:${"hello world"?capitalize}
 4. 字符串大写: ${"hello,world"?upper_case}
 5. 字符串小写:${"hello,world"?lower_case}

7.date,time,datetime将字符串转换为日期

${dateValue?date}
${dateValue?time}
${dateValue?datetime}
格式化日期: ${dateValue?string('yyyy-MM-dd HH:mm:ss')}

注意:如果指定的字符串格式不正确将引发错误


7.5 starts_with判断是否以xxx 开头

${"hello,world"?starts_with("hello")?string}    
<#if "hello,world"?starts_with("hello")>
  hello,world 以字符串 hello 开头
</#if>

8.ends_with 判断某个字符串是否由某个子串结尾,返回布尔值

${"hello,world"?ends_with("world")?string}  
<#if "hello,world"?ends_with("world")>
 hello,world 以字符串 world 结尾
</#if>

注意:布尔值必须转换为字符串才能输出


9.html 用于将字符串中的<、>、&和”替换为对应得<>":&


8.index_of(substring,start)在字符串中查找某个子串,返回找到子串的第一个字符的索引,如果没有找到子串,则返回-1。


Start参数用于指定从字符串的那个索引处开始搜索,start为数字值。如果start大于字符串长度,则start取值等于字符串长度,如果start小于0,则start取值为0。

${"hello,world"?index_of("o")}
${"hello,world"?index_of("aaa")}

10.length返回字符串的长度

${"hello,world"?length}


12.contains 判断字符中是否包含某个子串。返回布尔值

${"hello,world"?contains("llo")?string};

注意:布尔值必须转换为字符串才能输出

13.number将字符串转换为数字

14.replace用于将字符串中的一部分从左到右替换为另外的字符串。

15.split使用指定的分隔符将一个字符串拆分为一组字符串

16.trim 删除字符串首尾空格

${"   hello,world   "?trim}• 1

【4】操作数字内置函数

1.c 用于将数字转换为字符串

${data?c}  • 1


.string用于将数字转换为字符串

Freemarker中预订义了三种数字格式:number,currency(货币)和percent(百分比),其中number为默认的数字格式转换。

 货币:${0.3?string.currency}
 百分比:${0.3?string.percent}
 数字(默认):${0.3?string.number}


【5】操作布尔值内置函数

string用于将布尔值转换为字符串输出


true转为”true”,false转换为”false”

foo?string("yes","no")



如果布尔值(foo为布尔值)是true,那么返回”yes”,否则返回no

类似于三目运算符:

${(user.sex=="1")?string("男","女")}


目录
相关文章
|
6月前
EL表达式和Jstl常见的用法
EL表达式和Jstl常见的用法
Thymeleaf 表达式工具类(#strings #dates #numbers #bools)
Thymeleaf 表达式工具类(#strings #dates #numbers #bools)
|
6月前
|
Java 数据库
el表达式与jstl的用法
el表达式与jstl的用法
|
6月前
|
Java
FreeMarker - 四种变量的用法
FreeMarker - 四种变量的用法
312 1
|
开发框架 前端开发 JavaScript
FreeMarker的基本语法
FreeMarker的基本语法
187 0
FreeMarker的基本语法
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
SpringBoot——Thymeleaf中的表达式基本对象、表达式功能对象
activiti 自定义函数解析juel表达式
activiti是支持juel表达式的,这个也很好用,但实际过程中需要支持类方法及变量。    原来项目中解析juel,这边有自定义一个方法的 代码如下: public String getStringByELAndFormData(String el...
2725 0