Jsp遍历后台传过来的List三种方法

2024-04-15 19:08

本文主要是介绍Jsp遍历后台传过来的List三种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1:使用jstl标签 (可以和自定义标签配合使用)

首先引用jstl标签


  1. <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>  


然后使用foreach标签


  1. <c:forEach items="${list}" var="user" varStatus="vs">  
  2.         <tr>  
  3.               
  4.              <td>  
  5.                 <s:property value="#vs.index+1"/>  
  6.              </td>  
  7.              <td align = "center">${user.PId}</td>  
  8.              <td align = "center">${user.PLoginname}</td>  
  9.              <td align = "center">${user.PUserName}</td>  
  10.              <td align = "center">${user.PEmail}</td>  
  11.              <td align = "center"><html:department pdeptid="${user.PDeptid}"></html:department></td> <!-- 自定义标签 -->  
  12.          </tr>  
  13. </c:forEach>  

可以用<c:if test="${not empty list}"></c:if>   和 <c:if test="${not empty list}"></c:if> 来处理是否为空的情况。如果不为空,显示值,为空的话,显示无记录等。

后台可以把list放到值栈或者放到request.例如:request.setAttribute("list", XXXXlist);

 

2:使用jsp内嵌java代码遍历List (在后台把List放到session中,如果是大数据量,不应使用此方法)

首先在后台把list放入到session中

copy
  1. request.getSession().setAttribute(<span style="color:#ff0000;">Data.ALLNEWSLIST</span>, list);  

红色标记的Data.ALLNEWSLIST 为常量 在com.xiami.onlineshop.common包下的Data类中定义

copy
  1. public static final String ALLNEWSLIST="ALLNEWSLIST";  


jsp代码:(注意标红的代码不要忘记引入对应的类)


  1. <%@ page language="java" import="java.util.*,<span style="color:#ff0000;">com.xiami.onlineshop.common.*,com.xiami.onlineshop.data.*" </span>pageEncoding="GBK"%>  
  2.   
  3. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  4. <html>  
  5.   <head>  
  6.      
  7.   </head>  
  8.     
  9.   <body>  
  10.     <%     
  11.         String ntype=null;  
  12.         int pagenum=1;  
  13.         if(request.getParameter("pagecurrent")!=null){   
  14.         pagenum=Integer.parseInt(request.getParameter("pagecurrent"));   
  15.     }   
  16.         List list=null;  
  17.         if(session.getAttribute(Data.ALLNEWSLIST)!=null){  
  18.             list = (List)session.getAttribute(Data.ALLNEWSLIST);  
  19.             int l = list.size();  
  20.             %>  
  21.         <table border=1 width="100%">  
  22.         <tr bgcolor="#8E8E8E">>>首页>商城动态</tr>  
  23.         </table>  
  24.               
  25.                   
  26.             <br><br>    </font></center>  
  27.             <font color=#272727><%=pagenum %><Br><br></font>  
  28.                 <table>  
  29.             <%  
  30.             for(int i=0;i<l;i++){  
  31.                 News news =(News)list.get(i);  
  32.                 ntype=news.getNtype();  
  33.                   
  34.                 %>  
  35.                     <tr bgcolor="#93FF93">  
  36.                         <td bgcolor="#6C6C6C"><%=news.getNid() %></td>  
  37.                         <td bgcolor="#ADADAD"><a href="servlet/ShowDetailNews?nid=<%=news.getNid() %>"><%=news.getNtitle() %></a></td>  
  38.                           
  39.                     </tr>  
  40.                 <%  
  41.             }  
  42.             %>  
  43.               
  44.                 </table><br>  
  45.                 <a href="servlet/ShowAllNews?page=1&type=<%=ntype %>">首页</a>   
  46.                 <a href="servlet/ShowAllNews?page=<%=pagenum-1 %>&type=<%=ntype %>">上一页</a>   
  47.                 <a href="servlet/ShowAllNews?page=<%=pagenum+1 %>&type=<%=ntype %>">下一页</a>   
  48.                 <a href="servlet/ShowNewsEndPage?type=<%=ntype %>">尾页</a>  
  49.                   
  50.             <%  
  51.         }  
  52.      %>  
  53.   </body>  
  54. </html>  



3:使用Struts标签


co
  1. <%@ taglib prefix="s" uri="/struts-tags"%>  

cop
  1. <s:iterator value="#request.userList" status="stat" id="sd">  
  2.                             <tr align="center">  
  3.                                 <td>  
  4.                                     <s:property value="#sd[6]" />  
  5.                                 </td>  
  6.                                 <td>  
  7.                                     <s:property value="#sd[1]" />                             <span style="WHITE-SPACE: pre">                         </span></td>  
  8.                                 <td>  
  9.                                     <s:property value="#sd[2]"></s:property>  
  10.                                 </td>  
  11.                                 <td>  
  12.                                     <s:property value="#sd[4]"></s:property>  
  13.                                 </td>  
  14.                                 <td>  
  15.                                     <s:property value="#sd[5]"></s:property>  
  16.                                 </td>  
  17.                             </tr>  
  18. </s:iterator>  

这篇关于Jsp遍历后台传过来的List三种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906666

相关文章

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A