常用的freemark语法(三)
一,符号的意义
1.0,单问号
?后面要加关键字,例如:<#if object?exists>object对象不为空</#if> <#if str??>${str?string}</#if><#--将str以字符串形式显示--> ${nowDate?time}<#--将现有时间以时间的格式显示,显示结果如:15:13:05--> ${nowDate?date}<#--以日期格式显示,如:2011-4-28-->(date的格式可以在freemarker.properties文件中配置)
单问号后面跟的是函数
其实?exists就相当于??
1.1,双问号
<#if orderParam.quliJycs?? && orderParam.quliJycs == '1'>已上传<#else>请上传</#if>
其中双问号意思就相当于 orderParam.quliJycs?exists 是否存在 ,判断为非空的,这句话的意思就是说如果orderParam.quliJycs存在并且值为1则是已上传。
1.1.1,三个问号
${(num.color)???string}
前连个问号是判断是否存在,后面一个问号是让它以String的类型输出
1.2,单个感叹号
${(user.name)!""} ${(user.name)!}
3,${user.name?default(‘xxx’)}//默认值xxx
4 ${(user.name)!"默认值"}
第一行是说如果为空就让值为空
第二行就是如果为空不会报错
第三行则是如果为空则值为默认值
第三行和第四行的作用是一样的。
但是前提条件都是user对象不能为空,这句话主要针对的是它的值
1.3,双感叹号
${abc!!},<#list strList!! as str >
比如${list strList as str},如果strList不存在,则freemarker是会报错的
而如果加上<#list strList!! as str >,则freemarker就会对忽略掉空变量而不会报错
1.4,判断非空
1、if和”??“
<#if age??>
无年龄值
<#/if>
2、$和!
${age!'0'}
如果age为null,默认给'0'
二,循环语句的应用
2.1,if else 语句
<#if student.studentAge lt 12> ${student.studentName}不是一个初中生 <#elseif student.studentAge lt 15> ${student.studentName}不是一个高中生 <#elseif student.studentAge lt 18> ${student.studentName}不是一个大学生 <#else> ${student.studentName}是一个大学生 </#if>
<#if condition>... <#elseif condition2>... <#elseif condition3>...... <#else>... </#if>
2.2,switch的应用
字符串
<#switch being.size> <#case "small"> This will be processed if it is small <#break> <#case "medium"> This will be processed if it is medium <#break> <#case "large"> This will be processed if it is large <#break> <#default> This will be processed if it is neither </#switch>
数字
<#switch x> <#case x = 1> 1 <#case x = 2> 2 <#default> d </#switch>
格式
<#switch value> <#case refValue1> ... <#break> <#case refValue2> ... <#break> ... <#case refValueN> ... <#break> <#default> ... </#switch>
三,集合
2.1,集合的长度
<#if student?size != 0></#if> 判断=的时候,注意只要一个=符号,而不是==
2.2,遍历list集合
User类 public class User{ private String username; private (省略set和get方法) } user.ftl <#--Freemarker遍历list--> 简单遍历list: <#list userList as user> 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} </#list> <#--Freemarker遍历list并应用list隐含变量item_index--> item_index使用: <#list userList as user> 第${user_index+1}个用户 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} </#list> <#--Freemarker遍历list并应用list隐含变量item_has_next--> item_has_next,size使用: <#list userList as user> 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} <#if !user_has_next> 共有${userList?size}最后一个用户是:${user.userName} </#if> </#list> <#--Freemarker遍历list并按用户年龄升序排序--> 按用户年龄升序排序: <#list userList?sort_by("age") as user> 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} </#list> <#--Freemarker遍历list并按用户年龄降序排序--> 按用户年龄降序排序: <#list userList?sort_by("age")?reverse as user> 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} </#list> <#--Freemarker遍历list当用户年龄大于21岁时,停止输出--> list中应用break: <#list userList?sort_by("age")?reverse as user> 用户名:${user.userName} 密 码:${user.userPassword} 年 龄: ${user.age} <#if (user.age>21) > <#break> </#if> </#list>
2.3,遍历map集合一
假设selectDateModel 是我们后台返回的map<String, String>; <#list selectDateModel?keys as key> <option value="${key}">${selectDateModel[key]}</option> </#list>
2.4,遍历map集合二
<#--freemarker map的应用--> <#--创建一个map,注意在freemarker中,map的key只能是字符串来作为key--> <#assign userMap={"1","刘德华","2":"张学友"}/> <#--获取map中的值--> ${userMap["1"]} <#--获取map的keys--> <#assign keys=userMap?keys/> <#--遍历map 首选获取key的集合--> <#list keys as key> key:${key}-value:${userMap["${key}"]} </#list> </br> <#--直接遍历map的第二种方式--> <#list userMap?keys as key> key:${key}--value:${userMap["${key}"]} </#list> </br> <#--直接遍历map的values--> <#list userMap?values as value> ${value} </#list>
3,其它
3.1,判断null,""
<#if object.param??&&object.param!="">${object.param!}<#else>请选择</#if>
常用的freemark语法(三)的更多相关文章
- PHP语法(三):控制结构(For循环/If/Switch/While)
相关链接: PHP语法(一):基础和变量 PHP语法(二):数据类型.运算符和函数 PHP语法(三):控制结构(For循环/If/Switch/While) 本文我来总结几个PHP常用的控制结构,先来 ...
- Python 基础语法(三)
Python 基础语法(三) --------------------------------------------接 Python 基础语法(二)------------------------- ...
- Freemaker FTL指令常用标签及语法
https://blog.csdn.net/pengpengpeng85/article/details/52070602 FTL指令常用标签及语法 注意:使用freemaker,要求所有标签必须闭合 ...
- 【知识库】-数据库_MySQL常用SQL语句语法大全示例
简书作者:seay 文章出处: 关系数据库常用SQL语句语法大全 Learn [已经过测试校验] 一.创建数据库 二.创建表 三.删除表 四.清空表 五.修改表 六.SQL查询语句 七.SQL插入语句 ...
- FTL指令常用标签及语法
FTL指令常用标签及语法注意:使用freemaker,要求所有标签必须闭合,否则会导致freemaker无法解析. freemaker注释:<#-- 注释内容 -->格式部分,不会输出 - ...
- JAVA中常用需要设置的三个环境变量(JAVA_HOME、CLASSPATH、PATH)
JAVA中常用需要设置的三个环境变量: JAVA_HOME.CLASSPATH.PATH (一) 配置环境变量:(相对路径) 1. JAVA_HOME=x:/jdk1.6.0 2. 用%JAVA_HO ...
- linux下常用语言的语法检查插件整理
linux下常用语言的语法检查插件 可以结合vim语法检查插件syntastic使用,具体请参考syntastic使用说明 如php,sql,json,css,js,html,shell,c等语法插件 ...
- {Django基础十之Form和ModelForm组件}一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 ModelForm
Django基础十之Form和ModelForm组件 本节目录 一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 Model ...
- Unit05: JavaScript对象概述 、 常用内置对象一 、 常用内置对象二 、 常用内置对象三
Unit05: JavaScript对象概述 . 常用内置对象一 . 常用内置对象二 . 常用内置对象三 常用内置对象使用演示: <!DOCTYPE html> <html> ...
随机推荐
- MySQL操作中的一些细节及良好习惯--------持续更新中...
1.尽量不要写太过复杂的SQL查询,不要想着非要一次性将结果全部以前端要求的形式返回出来,可以多次分开查询,这样逻辑清晰,问题解决速度快,方便维护,并且SQL的效率也高. 2.在使用联表查询的时候,关 ...
- [Python Study Notes] Python的安装
Windows: 1.下载安装包: 转到Python官网https://www.python.org/downloads/ ,下载最新版本的Python. 2.安装 安装到自定义的安装路径下. 3. ...
- java单例模式学习笔记
最近一直在学习多线程,在学习过程中遇到了关于单例模式的多线程安全问题,内容如下: 一:首先什么是单例模式 单例模式具有的三要点: 一个类只能有一个实例: 必须是由它自己创建的这个实例: 它必须自行向外 ...
- Zabbix 3.0 监控Web
zabbix 界面配置 触发器添加
- MySQL统计函数记录——按月、按季度、按日、时间段统计
按年汇总,统计:select sum(mymoney) as totalmoney, count(*) as sheets from mytable group by date_format(col, ...
- CENTOS6.6下mysql MMM架构搭建
本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn MMM(Master-Master replication mana ...
- C#中引用变量是否应该加ref?
看如下代码: void Test(T t); void Test(ref T t); 当T是值类型的时候,很好判断,第一种并不能改变方法外变量的值,需要第二种方法才可以.通过查看IL代码,可以看到 ...
- Yii2中后台用前台的代码设置验证码显示不出来?
我说的是直接修改advanced模板.细心人会发现模板里在contact里有,登录也想要就仿照contact中的做法.前台好了,后台登录也要验证码,就把前台代码拿过来,可惜前后台的SiteContro ...
- Mysql取随机数据效率测试(400W条中读取100条)
测试数据表的创建在文章:http://www.cnblogs.com/wt645631686/p/6868192.html 先看一下我的SQL方案 SELECT * FROM `emp` WHERE ...
- Windows下如何硬盘安装Ubuntu
一般来说,折腾双系统是每一位程序猿都有过的经历,如何在windows下安装双系统ubuntu呢?今天来给大家介绍一下如何直接在windows硬盘安装ubuntu,而不需要使用U盘或者光盘,或外置硬盘. ...