java map在JSTL EL中的小应用--<c:forEach>遍历Map<>泛型
准备数据
/** 结构示意图:
类型: List集合 map对象 LIst集合 Person类对象 String name ; int age mList -> map() ->pList ->Person p1 坤哥 24
->Person p2 鲲哥 104
->pList2
->Person ps1 王小三 24
->Person ps2 王小二 24
-> map2()
->pList3
->Person pr1 张咪咪 19
->Person pr2 赵咪咪 21
- >pList4
->Person pd1 谢广坤 54
->Person pd2 赵四 56 (可能是吧)
*/
Map所需包 (只限JSTL中)
java.util.HashMap
java.util.Map
常 见 Map 指 令 清 单
1. 创建map
Map<String,List<Person>> map = new HashMap<String,List<Person>>();
List<Map<String,List<Person>>> mList = new ArrayList<Map<String,List<Person>>>();
其实结构确实不难的。(O - O)```
2. map添加数据
map.put("谢广坤",54)
3. 获取key
map.keySet() 和 map.entrySet()
本处用keySet()。因为我菜,用entrySet()遍历的数据不太正常,哪天解决了再写吧。
4. 获取value
map.values() 注意 ‘ s ’
我 的 主 要 代 码
1. 数据准备
//以谢广坤为例
List<Person> pList4 = new ArrayList<Person>();
Person pd1 = new Person("谢广坤",54);
Person pd2 = new Person("赵四",56);
pList4.add(pd1);pList4.add(pd2);
//。。。
Map<String,List<Person>> map2 = new HashMap<String,List<Person>>();
map2.put("pList4",pList4);
//。。。
List<Map<String,List<Person>>> mList = new ArrayList<Map<String,List<Person>>>();
mList.add(map2);
2. 输出所有数据
<c:forEach items="${mList}" var="m" varStatus="id">
<h2>第${id.count}个map</h2>
<c:forEach items="${m.keySet()}" var="k">
<h3>List的名字是:<c:out value="${k}"></c:out></h3>
<c:forEach items="${m.values()}" var="l">
<c:forEach items="${l}" var="p">
<table border="1px dotted blue">
<tr>
<th>姓名</th>
<th>年龄</th>
</tr>
<tr>
<td>${p.name}</td>
<td>${p.age}</td>
</tr>
</table>
<br>
</c:forEach>
</c:forEach>
</c:forEach>
</c:forEach>
3. 输出年龄大于50的乡村爱情人物
<c:forEach items="${mList}" var="m">
<c:forEach items="${m.values()}" var="l">
<c:forEach items="${l}" var="p">
<c:if test="${p.age>50}">
<table border="2px dotted blue">
<tr>
<th>姓名</th>
<th>年龄</th>
</tr>
<tr>
<td>${p.name}</td>
<td>${p.age}</td>
</tr>
</table>
</c:if>
</c:forEach>
</c:forEach>
</c:forEach>
结 果 样 子
大概就是这个样子

java map在JSTL EL中的小应用--<c:forEach>遍历Map<>泛型的更多相关文章
- Java实现 LeetCode 671 二叉树中第二小的节点(遍历树)
671. 二叉树中第二小的节点 给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2 或 0.如果一个节点有两个子节点的话,那么这个节点的值不大于它的子节点的值. 给出这样的 ...
- 在JSTL EL中处理java.util.Map,及嵌套List的情况
关联的键查找存储在映射中的值. 在方括号中指定键,并将相应的值作为表达式的值返回.例如,表达式 ${map['key']} 返回与 map标识符所引用的 Map 中的 "key" ...
- java 11-8 在大串中查找小串的案例
1.统计大串中小串出现的次数 举例: 在字符串"woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun& ...
- js中三个对数组操作的函数 indexOf()方法 filter筛选 forEach遍历 map遍历
indexOf()方法 indexOf()方法返回在该数组中第一个找到的元素位置,如果它不存在则返回-1. 不使用indexOf时 var arr = ['apple','orange','pea ...
- 空数组在以下三种遍历中均不可更改:forEach、map和for...in
首先,我们要知道对于forEach.map和for...in三种遍历,在不是空数组的情况下,要想实现更改原数组的方法,代码如下: var list = [1,2,3,4]; var list1 = [ ...
- 【java】TreeMap/HashMap的循环迭代中 keySet和entrySet和forEach方式 + map的几种迭代方式
参考链接:https://www.cnblogs.com/crazyacking/p/5573528.html ================================== java紫色代表迭 ...
- 获取map中的一个value值以及遍历map获得map里所有key、value的值
前言: 1.声明一个map: Map map = new HashMap();2.向map中放值,注意:map是key-value的形式存放的.如: map.put(”sa”,”dd”); 3.从ma ...
- ES6中变量解构的用途—遍历Map结构
- 谈谈java中遍历Map的几种方法
java中的map遍历有多种方法,从最早的Iterator,到java5支持的foreach,再到java8 Lambda,让我们一起来看下具体的用法以及各自的优缺点 先初始化一个map public ...
随机推荐
- Chrome插件安装的3种方法,解决拖放不能安装的情况,并提供插件下载
本文摘录于Chrome插件网站 方法一:拖放安装 下载插件的crx文件后,打开Chrome的扩展页面(chrome://extensions/或按Chrome菜单图标>更多工具>扩展程序) ...
- PHP和JavaScript中奖概率算法
这是一个经典的概率算法. 现在有数组:[10, 20, 30, 40] . 假设对应中奖几率:特等奖10%,一等奖20%,二等奖30%,三等奖40%,总共100%. 算法开始时,从数组中选出一个值$v ...
- python1:基础数据类型(上)
https://www.geekdigging.com/2019/10/13/2870915864/ 1.数字 在python的数字有4钟数据类型,分别是: int(有符号整型) long(长整型) ...
- mysql 替换 tab 键 (\t)
update t_instance set instance_name = replace(instance_name,'\t','') , host_name = replace(host_name ...
- Swoole 是 PHP 中的 Node.js?
一想到那些可以使用 Node 的同事,一些 PHP 开发者的脸都嫉妒绿了.异步 Node 系统可以在不同协议间共享代码库,并在代码之外提供服务.这真的想让一个人转 Node 开发.实际上 PHP 中也 ...
- 3分钟了解ServiceStage 应用智能化运维【华为云分享】
[摘要] 微服务云应用平台(ServiceStage)是面向企业及开发者的一站式DevOps平台服务,支持基于微服务的应用开发.治理.部署及运维监控的全生命周期管理,并提供大规模容器集群管理及中间件服 ...
- 搞清楚一道关于Integer的面试题
请看题1: public class IntegerDemo { public static void main(String[] args) { Integer a = 888; Integer b ...
- LNMP的搭建 及地址转换
1. LNMP 先安装nginx yum -y install gcc openssl-devel pcre-devel wget http://nginx.org/download/ngin ...
- luogu P1722 矩阵 II
题目背景 usqwedf 改编系列题. 题目描述 如果你在百忙之中抽空看题,请自动跳到第六行. 众所周知,在中国古代算筹中,红为正,黑为负-- 给定一个1*(2n)的矩阵(usqwedf:这不是一个2 ...
- git 使用详解(3)—— 最基本命令 + .gitignore 文件
Git 基础 本章将介绍几个最基本的,也是最常用的 Git 命令,以后绝大多数时间里用到的也就是这几个命令.读完本章,你就能初始化一个新的代码仓库,做一些适当配置:开始或停止跟踪某些文件:暂存或提交某 ...