我是靠谱客的博主 纯真枫叶,最近开发中收集的这篇文章主要介绍笔记 freemark list标签迭代Map集合排序问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处。

  工作中出现一个比较特殊的问题,在模板ftl文件中,一般用list迭代map

举例:  

  后台:

    // 传入的参数

    Map<Map<String,Object>> itemMap = new LinkedHashMap<Map<String,Object>>();

    .......  // put数据进入itemMap中

    print: {2:{name:"king"},1:{name:"arise"}}

  前端模板文件:

  <#list itemMap?keys as key>

     key: ${key}---- value: ${itemMap[key].name} <br />

  </#list>

  展示效果为:

  key: 1 ----- value: arise

  key: 2 ----- value: king

  这里就有问题了,后台传过来的是一个链表结构的map,应该以存入的顺序进行展示才对.

  原因:

    <#list itemMap?keys as key> 中,list标记户对所有的key进行一个默认的排序,所以顺序与后台传过来的不一样

  解决办法目前有两种(以后发现了再添加上来):

  (1). [推荐] 后台传过来的LinkedHashMap换成LinkedList,存储键值对的方式也要变,如果需要在页面展示key的话,并且前端展示用一下代码

    后台:

         List<Map<String,Object>> itemList= new LinkedList<Map<String,Object>>();

      .......  // put数据进入itemMap中

      print: [{key:2,name:"king"},{key:1,name:"arise"}]

    前端模板文件:

    <#list itemList as item>

      key: ${item.key}---- value: ${item.name} <br />

    </#list>

    展示效果为:

    key: 1 ----- value: arise

    key: 2 ----- value: king

  (2). 后台传一个itemMap以及一个itemMap的所有键组成的list到ftl文件中,然后页面遍历由键组成的list,并在通过键得到itemMap中的value

转载于:https://www.cnblogs.com/king-xg/p/7053908.html

最后

以上就是纯真枫叶为你收集整理的笔记 freemark list标签迭代Map集合排序问题的全部内容,希望文章能够帮你解决笔记 freemark list标签迭代Map集合排序问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部