Freemarker中如何遍历List(附源码)

关键词(Keyword):Freemarker,Freemarker遍历list

在Freemarker应用中经常会遍历List获取需要的数据,并对需要的数据进行排序加工后呈现给用户。那么在Freemarker中如何遍历List,并对List中数据进行适当的排序呢?

通过下文的介绍,相信您一定会找到答案。

一、  Freemarker中list指令简单介绍

要想在Freemarker中遍历list,必须通过使用list指令,即<#list sequence as item>…</#list>

sequence是集合(collection)的表达式,item是循环变量的名字,不能是表达式。

当在遍历sequence时,会将遍历变量的值保存到item中。

举个例子说明吧:

<#list userList as user>

  …

</#list>

  userList中封装了很多个User对象,我们在遍历userList时候,会将遍历的User对象的值,保存到上述的user变量中。那么在取值时,我们可以通过${user.userName }来获取User对象的userName属性值。

  List指令还隐含了两个循环变量:

item_index:当前迭代项在所有迭代项中的位置,是数字值。

item_has_next:用于判断当前迭代项是否是所有迭代项中的最后一项。

注意:在使用上述两个循环变量时,一定要将item换成你自己定义的循环变量名,item其实就是前缀罢了。

例如,如果你使用<# list list as l>..</#list>定义,那么就要使用l_index,l_has_next。

 

  在循环过程中,如果您想跳出循环,那么可以使用结合break指令,即<#break>来完成。

二、  Freemarker中对List进行排序

通常我们的排序操作都是通过DAO层来实现的,如果我们想随时更改我们的排序,那么就必须修改我们的DAO层代码,确实不方便。但Freemarker为我们提供了这样的排序方法,解决了这个问题。

1.  sort升序排序函数

sort对序列(sequence)进行排序,要求序列中的变量必须是:字符串(按首字母排序),数字,日期值。

<#list list?sort as l>…</#list>

2.  sort_by函数

sort_by有一个参数,该参数用于指定想要排序的子变量,排序是按照变量对应的值进行排序,如:

<#list userList?sort_by(“age”) as user>…</#list>

age是User对象的属性,排序是按age的值进行的。

3.  reverse降序排序函数

   
<#list list? reverse as l>…</#list>。reverse使用同sort相同。reverse还可以同sort_by一起使用

如:想让用户按年龄降序排序,那么可以这个样写<#list userList?sort_by(“age”)?reverse as user>…</#list>

三、  Freemarker如何遍历List实例应用

创通过上面的介绍,相信您已经对Freemarker如何遍历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>

ClientTest类

public class ClientTest{

  public static List<User> initUserList(){

   


User user1=new User();

   
user1.setUserName("张三");

   
user1.setUserPassword("123");

   
user1.setAge(20);

   


   
User user2=new User();

   
user2.setUserName("李四");

   
user2.setUserPassword("123");

   
user2.setAge(22);

   


   
User user3=new User();

   
user3.setUserName("王五");

   
user3.setUserPassword("123");

   
user3.setAge(21);

List<User> list=new ArrayList<User>();

   
list.add(user1);

   
list.add(user2);

list.add(user3);

return list;

}

public static void main(String[] args){

  List<User> list=ClientTest.initUserList(); 


Map<String,Object> root=new HashMap<String,Object>();

root.put(“userList”,list);

  FreeMarkertUtil.analysisTemplate(“user.ftl”,”UTF-8”,root);

//FreeMarkUtil类可以参考我上传得源码。

}

}

好了,到这里程序就结束了,您可以运行ClientTest类来查看输出结果了。

希望通过本文的介绍,可以让您对FreeMarker如何遍历List有一个清楚的了解。

Freemarker中如何遍历List的更多相关文章

  1. Freemarker中遍历List以及内置函数使用

    在Freemarker应用中经常会遍历List获取需要的数据,并对需要的数据进行排序加工后呈现给用户. 那么在Freemarker中如何遍历List,并对List中数据进行适当的排序呢?一. Free ...

  2. [转]freemarker中的list

    转至:http://zhuyuehua.iteye.com/blog/1975251 freemarker list (长度,遍历,下标,嵌套,排序) 1. freemarker获取list的size ...

  3. freemarker中的list 前端模板

    freemarker list (长度,遍历,下标,嵌套,排序)1. freemarker获取list的size : JavaArrayList<String> list = new Ar ...

  4. [LeetCode] Construct Binary Tree from Preorder and Inorder Traversal 由先序和中序遍历建立二叉树

    Given preorder and inorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  5. [LeetCode] Binary Tree Inorder Traversal 二叉树的中序遍历

    Given a binary tree, return the inorder traversal of its nodes' values. For example:Given binary tre ...

  6. nyoj202_红黑树_中序遍历

    红黑树 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 什么是红黑树呢?顾名思义,跟枣树类似,红黑树是一种叶子是黑色果子是红色的树... 当然,这个是我说的... & ...

  7. DS实验题 Order 已知父节点和中序遍历求前、后序

    题目: 思路: 这题是比较典型的树的遍历问题,思路就是将中序遍历作为位置的判断依据,假设有个节点A和它的父亲Afa,那么如果A和Afa的顺序在中序遍历中是先A后Afa,则A是Afa的左儿子,否则是右儿 ...

  8. YTU 2346: 中序遍历二叉树

    原文链接:https://www.dreamwings.cn/ytu2346/2606.html 2346: 中序遍历二叉树 时间限制: 1 Sec  内存限制: 128 MB 提交: 12  解决: ...

  9. smarty中section遍历数组

    smarty中section遍历数组

随机推荐

  1. SSD-Tensorflow: 3 步运行 TensorFlow 单图片多盒目标检测器

    昨天类似的 YOLO: https://www.v2ex.com/t/392671#reply0 下载这个项目 https://github.com/balancap/SSD-Tensorflow 解 ...

  2. 阿里 & 酷家乐:实习生面试

    最近海投了十家公司,暂时有阿里两面(已凉).酷家乐两面(大概凉了).网易一面.前两个都是基础知识发挥得还可以,两家公司二面都凉凉. 阿里一面(3.21 26min) 刚好买了中饭回宿舍打开正准备吃的时 ...

  3. Cisco 的基本配置实例之五----交换机的路由功能与DHCP 功能

    5.配置交换机的路由功能 说明:只有在三层交换机上才有路由功能,其他的二层接入交换机要想在不同的vlan之间传送数据需要通过trunk口到核心交换机上进行完路由交换后才可以. TEST(config) ...

  4. Object 类

  5. javascript requestAnimationFarme

    今天看到一篇很好的文章推荐一下:原文地址:http://www.zhangxinxu.com/wordpress/?p=3695 CSS3动画那么强,requestAnimationFrame还有毛线 ...

  6. 迭代器&生成器

    迭代器 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退 ...

  7. OpenSuSE Linux下安装Oracle10g的步骤

    OpenSuSE Linux下安装Oracle10g的步骤: --root用户 --1.vi etc/profile 添加脚本: if [ \$USER = "oracle" ]; ...

  8. init,initialize,initWithFrame,initWithCoder,awakeFromNib等区别

    1.init 与initialize 对于iOS程序,创建几个类对象,就会调用几次init.下面分别重写 举例如下: 创建一个Person类,分别重写initialize和init方法 #import ...

  9. Redis之(七)主从同步与集群管理

    8.1 主从同步原理 像MySQL一样,Redis是支持主从同步的,而且也支持一主多从以及多级从结构. 主从结构,一是为了纯粹的冗余备份,二是为了提升读性能,比如很消耗性能的SORT就可以由从服务器来 ...

  10. ThreadLocal深入剖析

    JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地编写出优美的多线程程序,Threa ...