Jsp实现页面forEach循环遍历多条数据的显示和后台对应数据的获取(strurs1)实现

使用jstl标签和form动态的页面数据显示操作获取!

html代码:

<body>
    <center>
    	<div id="header"></div>
    	<div id="divuser">
<input id="contextPath" type="hidden" value="${pageContext.request.contextPath}"/>    	<form id="userform">
    		<table id="usertb" width="655" border="0" cellpadding="2" cellspacing="0">
    		<caption>用户信息表</caption>
    			<c:if test="${empty userList}">
    				<tr>
    					<td><span>user data is null!</span></td>
    				</tr>
    			</c:if>
    			<c:forEach items="${userList}" var="user" varStatus="userStatus">
    				<tr>
    				  <td width="40" align="center" class="tb_td_border">
			          <input id="uid${userStatus.index}" name="uid" type="radio" value="${userStatus.index}" />
				  </td>
    				  <td width="100" align="center" class="tb_td_border">
				    <label for="uid${userStatus.index}"><span class="font12_blue">${user.userName }</span></label>
				  </td>
    				  <td width="100" align="center" class="tb_td_border">
				    <label for="uid${userStatus.index}"><span class="font12_blue">${user.userGender}</span></label>
				  </td>
    				  <td width="100" align="left" class="tb_td_border">
				    <label for="uid${userStatus.index}"><span class="font12_blue">${user.userEmail }</span></label>
				  </td>
    				  <td width="100" align="center" class="tb_td_border">
				    <label for="uid${userStatus.index}"><span class="font12_blue">${user.userBirthDay }</span></label>
				  </td>
    				  <td width="100" align="center" class="tb_td_border">
				    <label for="uid${userStatus.index}"><span class="font12_blue">${user.userAddress }</span></label>
				  </td>
    				  <td width="110" align="center" class="tb_td_border">
    				    <div id="divnickname${userStatus.index}">
<input id="nickname${userStatus.index }" name="nickname" type="text" class="font12_blue" maxlength="7" style="width: 100;" value="" onfocus="radiocheckbytextfocus(this);" />
    				    </div></td>
    				</tr>
    					<input name="userId" type="hidden" value="${user.userId }" />
    				        <input name="userName" type="hidden" value="${user.userName }" />
    					<input name="userGender" type="hidden" value="${user.userGender}" />
    					<input name="userEmail" type="hidden" value="${user.userEmail }" />
    					<input name="userBirthDay" type="hidden" value="${user.userBirthDay }" />
    					<input name="userAddress" type="hidden" value="${user.userAddress }" />
    			</c:forEach>
	    			<tr>
	    				<td colspan="7" align="right">
	    					<input type="button" id="btsubmit" name="btsubmit" value="go>>..." />
	    				</td>
    				</tr>
    		</table>
    	</form>
    	</div>
    	<div id="divbodyer"></div>
    	<hr size="2" noshade="noshade" width="665px" color="#4DFFFF"; />
    	<div id="div2user">
    		<table id="tbusernn" width="665" cellpadding="0" cellspacing="0" border="0">
				<c:if test="${empty userLink}">
					<tr>
						<td>user data is null!</td>
					</tr>
				</c:if>
				<c:forEach items="${userLink}" var="usernn" varStatus="usernnStatus">
					<tr>
					<td width="100" align="center">${usernn.key }</td>
					<td align="center">${usernn.value.id } - ${usernn.value.name } - ${usernn.value.phone }</td>
					</tr>
				</c:forEach>
    		</table>
    	</div>
    </center>
  </body>

注解:<label for="uid${userStatus.index}"> for标签:for 属性规定 label 与哪个表单元素绑定(显示的联系),点击文本就会自动选中,当前for指向id的radio按钮。
 jstl的c:forEach标签的属性:用于通用数据循环,它的属性:

    items(属 性):进行循环的项目 (描述),否(是否必须),无(缺省值)

    var:代表当前项目的变量名,否,无

    varStatus:显示循环状态的变量,否,无

    begin:开始条件,否,0

    end:结束条件,否,集合中的最后一个项目

    step:步长,否,1

jstl中的varStatus和 var 属性一样, varStatus 用于创建限定了作用域的变量。不过,由 varStatus 属性命名的变量并不存储当前索引值或当前元素,而是赋予 javax.servlet.jsp.jstl.core.LoopTagStatus 类的实例。该类定义了一组特性,它们描述了迭代的当前状态,下面列出了这些特性:

<c:forEach var=”user" items=”${users}" varStatus=”status”>
<c:out value=”${status.current}”/> 当前对象
<c:out value=”${status.index}”/> 此次迭代的索引
<c:out value=”${status.count}”/> 已经迭代的数量
<c:out value=”${status.first}”/> 是否是第一个迭代对象
<c:out value=”${status.last}”/> 是否是最后一个迭代对象
</c:forEach>

<c:forEach>标签的items属性支持Java平台所提供的所有标准集合类型。此外,您可以使用该操作来迭代数组(包括基本类型数组)中的元素。它所支持的集合类型以及迭代的元素如下所示:
java.util.Collection:调用iterator()来获得的元素。
java.util.Map:通过java.util.Map.Entry所获得的实例。
java.util.Iterator:迭代器元素。
java.util.Enumeration:枚举元素。
Object实例数组:数组元素。
基本类型值数组:经过包装的数组元素。
用逗号定界的String:分割后的子字符串。
javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。
并且使用“index”可以动态的使用js操作页面元素,和后台获取请求数据。

js代码:

$(document).ready(function(){
	//submit html data
	$("#btsubmit").click(function(){
		var raduid = $("input[name=uid]:checked").val();
		if(raduid == null || raduid == ""){
			alert("请选择用户");
			return;
		}
		var userForm = $("#userform").get(0);
var path = $("#contextPath").val();		userForm.action =path+"/usergetinfo.do?param=getHtmlUserInfo";
		userForm.method = "post";
		userForm.submit();
		$("#btsubmit").prop("disabled",true);
	});
});
//鼠标进入文本框,自动选中radio
function radiocheckbytextfocus(obj){
	var nicknameId = $(obj).attr("id");
 	var radioId = nicknameId.substring(8);
	var uidId = "#uid"+radioId;
	$(uidId).prop("checked",true);
}

注解:$( elem ).attr( "checked" )
1.6版本前返回值为boolean,1.6+返回值为string,为属性的实际值,而不是boolean.
新的浏览器返回的是“checked”,老的浏览器返回的是true,所以不能使用attr ;.prop()方法被用来处理boolean attributes。

页面隐藏多条数据,值显示几条可以:

function bkchange(obj)
{
var img_path=obj.src;  

 if (img_path.lastIndexOf("images/jiantouup.jpg")>=0)
 {
	 obj.src="images/jiantoudown.jpg";
	 $("tr[class='bkhide']").show();
 }
 else{
	 obj.src="images/jiantouup.jpg";
	 if($("input[name=uid]:checked").val()+1>3){
	 $("input[name=sid]").attr("checked",false);
	 }
	 $("tr[class='bkhide']").hide();
 }
}

js操作表格迭代操作数据(迭代行下列获取单元格数据):

	 	$("#tbuser tr").each(function(){
		//get user name
	 		var userName = $(this).children("td").eq(1).text().trim();
	 	});

js使用“$(obj).attr("id");”获取当前的id。或者$(this).attr("id");

js提交异步提交表单表单,数据为“$("#userForm").serialize()”,可以使用:

$.ajax({
		url:"getNickName.do?uid="+index,
		type:"post",
		timeout:20000,
		data:$("#userForm").serialize(),
		success:function(data){
			if(data==null){
				data = "";
			}
			$(divuserhint).html("");
			$(userId).attr("value",data);
			clockradio("query");//callback "query"=method flag
		},
		error:function(){
			$(userId).attr("value","");
			$(divuserhint).html(user_info[3]);//js i18n
		}
	});

 struts的配置文件(struts-config.xml):

  <form-beans>
  	<form-bean name="UserDataForm" type="com.ts.form.UserDataForm"></form-bean>
  </form-beans>
  <action path="/usergetinfo" name="UserDataForm" parameter="param"  scope="request"
    type="com.ts.actions.UserDataAccessAction">
	<forward name="success" path="/tsjsp/userinfo.jsp"></forward>
  </action>

Action处理:

package com.ts.actions;
import java.io.UnsupportedEncodingException;
import java.util.LinkedHashMap;
import java.util.Vector;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.apache.log4j.Logger;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.actions.DispatchAction;
import com.ts.services.vo.LinkUser;
import com.ts.services.vo.UserSVo;
import com.ts.testdatas.LinkedMapTestData;
import com.ts.testdatas.UserTestData;

 /**
 * ClassName: LinkedMapDataAccessAction <br/>
 * Date: 2015-1-14 上午10:20:49 <br/>
 * <br/>
 *
 * @author tskk@ts.com
 *
 * first made
 * @version 0.0.1<br/>
 *
 */

public class UserDataAccessAction extends DispatchAction {
    //log
    private static final Logger LOG = Logger.getLogger(UserDataAccessAction.class);
    /**
     *
     * getUserInfo:users information <br/>
     * @param mapping mapping
     * @param form form
     * @param request request
     * @param response response
     * @return forword mapping <br/>
     */
    public ActionForward getDBUserInfo(ActionMapping mapping, ActionForm form, HttpServletRequest request,HttpServletResponse response){
        //get request session
        HttpSession session = request.getSession();
        Vector<UserSVo> userList = UserTestData.getUserTestData();
        LOG.info("userList - :"+userList.size());
        session.setAttribute("userList", userList);
        return mapping.findForward("success");
    }
    /**
     *
     * getUserInfo:users information <br/>
     * @param mapping mapping
     * @param form form
     * @param request request
     * @param response response
     * @return forword mapping <br/>
     * @throws UnsupportedEncodingException if has error
     */
    public ActionForward getHtmlUserInfo(ActionMapping mapping, ActionForm form, HttpServletRequest request,HttpServletResponse response){
        //get request session
        HttpSession session = request.getSession();
        //set request encoding
        try {
            request.setCharacterEncoding("GBK");
        } catch (UnsupportedEncodingException e) {
            LOG.info("set request encoding failure!");
        }
        StringBuffer sf = new StringBuffer();
        //get html request data
        int uid = Integer.parseInt(request.getParameter("uid"));
        sf.append("uid:"+uid);
        String userId = request.getParameterValues("userId")[uid];
        sf.append(" name:"+userId);
        String name = request.getParameterValues("userName")[uid];
        sf.append(" name:"+name);
        String gender = request.getParameterValues("userGender")[uid];
        sf.append(" gender:"+gender);
        String email = request.getParameterValues("userEmail")[uid];
        sf.append(" email:"+email);
        String birthDay = request.getParameterValues("userBirthDay")[uid];
        sf.append(" birthDay:"+birthDay);
        String address = request.getParameterValues("userAddress")[uid];
        sf.append(" address:"+address);
        String nickName = request.getParameterValues("nickname")[uid];
        sf.append(" nickname:"+nickName);
        LOG.info(sf.toString());
        LinkedMapTestData linkdata = new LinkedMapTestData();
        LinkedHashMap<String, LinkUser> userLink = linkdata.getLinkedHashMapData(userId, nickName);
        LOG.info("userLink- :"+userLink.size());
        session.setAttribute("userLink", userLink);
        return mapping.findForward("success");
    }
}

可以通过"String name = request.getParameterValues("userName")[uid];"获取页面上的数据(radio=checked)。

此处数据用Vector和linkedHashMap存储:

public class UserTestData {
    public static Vector<UserSVo> getUserTestData(){
        Vector<UserSVo> userList = new Vector<UserSVo>();
        UserSVo usertttian = new UserSVo("us1", "甜甜", "22", "女", "18707005525", "ttian@ts.com", "1992-02-08", "北京朝阳", "研究生","xiaoA");
        UserSVo userkke = new UserSVo("us2", "可可", "20", "女", "18707005526", "kke@ts.com", "1994-02-07", "北京昌平", "本科","xiaoB");
        UserSVo userkka = new UserSVo("us3", "卡卡", "19", "女", "18707005527", "kka@ts.com", "1995-02-06", "天津西青", "高中","xiaoC");
        UserSVo userddan = new UserSVo("us4", "淡淡", "18", "女", "18707005528", "ddan@ts.com", "1996-02-05", "兰州城关", "高中","xiaoD");
        UserSVo usernna  = new UserSVo("us5", "娜娜", "17", "女", "18707005529", "nna@ts.com", "1997-02-04", "甘肃临夏", "初中","xiaoE");
        userList.add(usertttian);
        userList.add(userkke);
        userList.add(userkka);
        userList.add(userddan);
        userList.add(usernna);
        return userList;
    }
}

 

public class LinkedMapTestData {
    LinkedHashMap<String, LinkUser> linkedHashMap = new LinkedHashMap<String, LinkUser>();

    public LinkedHashMap<String, LinkUser> getLinkedHashMapData(String userId,String nickName) {
        Vector<UserSVo> vector = UserTestData.getUserTestData();
        UserSVo user = null;
        for(int i=0,j=vector.size();i<j;i++){
            user = vector.get(i);
            LinkUser userlink = user.getUser();
            userlink.setId(user.getUserId());
            userlink.setName(user.getUserName());
            userlink.setPhone(user.getUserPhone());
            if(user.getUserId().equals(userId)){
                user.setUserNickName(nickName);
            }
            linkedHashMap.put(user.getUserNickName(),userlink);
        }
        return linkedHashMap;
    }
}

此处的LinkedHashMap中key和value中放了对象,在页面可以通过“${usernn.value.id }”或“${usernn.key.id }”获取其中的值显示。

时间: 2024-08-03 19:18:11

Jsp实现页面forEach循环遍历多条数据的显示和后台对应数据的获取(strurs1)实现的相关文章

foreach循环遍历数组搞不懂执行顺序思路

问题描述 foreach循环遍历数组搞不懂执行顺序思路 搞不懂if判断那一块 最好有大神能给详细说明一下执行顺序 解决方案 这也没那么复杂http://blog.csdn.net/china_skag/article/details/6444727

MongoDB数据库forEach循环遍历用法_MongoDB

MongoDB数据库forEach语句循环遍历功能是非常常用的一个功能. 采用foreach循环遍历,并每次循环允许执行一次回调函数. 此外,foreach循环遍历是for循环的一种扩展,对比同浏览器端的forEach用法是一致的. 示例如下: >var arr = ["ab","cd","ef"] >var show = function(value,index,ar){ print(value) } >arr.forEach

C#使用foreach循环遍历数组完整实例_C#教程

本文实例讲述了C#使用foreach循环遍历数组的方法.分享给大家供大家参考,具体如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { //声明数组. 第一种方法. 声明并分配元素大小. int[] Myint

遍历-求大神指点 关于java 的foreach循环问题

问题描述 求大神指点 关于java 的foreach循环问题 import java.util.Arrays; public class lianxi02 { public static void main(String[] args) { // 定义一个整型数组,保存成绩信息 int[] scores = { 89 72 64 58 93 }; // 对Arrays类对数组进行排序 Arrays.sort(scores); // 使用foreach遍历输出数组中的元素 for (int sco

Javascript数组循环遍历之forEach详解_基础知识

1.js 数组循环遍历. 数组循环变量,最先想到的就是 for(var i=0;i<count;i++)这样的方式了. 除此之外,也可以使用较简便的forEach 方式 2.forEach函数. Firefox 和Chrome 的Array 类型都有forEach的函数.使用如下: <!--Add by oscar999--> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> &l

Java中遍历数组使用foreach循环还是for循环?_java

从JDK1.5起,增加了新功能Foreach,它是for循环遍历数据的一种简写形式,使用的关键字依然是for,但参数格式不同.其详细用法为: for(Type e:collection){ //对变量e的使用} 参数说明: e:其类型Type是集合或数组中元素值的类型,该参数是集合或数组collection中的一个元素. collections: 要遍历的集合或数组,也可以是迭代器. 在循环体中使用参数e,该参数是foreach从集合或数组以及迭代器中取得的元素值,元素值是从头到尾进行遍历的.

ArrayList和LinkedList的几种循环遍历方式及性能对比分析

主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以了解(1)List的五种遍历方式及各自性能 (2)foreach及Iterator的实现 (3)加深对ArrayList和LinkedList实现的了解. 阅读本文前希望你已经了解ArrayList顺序存储和LinkedList链式的结构,本文不对此进行介绍. 相关:HashMap循环遍历方式及其性

Java for-each循环使用难题2例(高级使用方法)_java

Java中,for-each循环简化了任何Collection或array的遍历过程,但并不是每个Java程序员都了解本文将要描述的for-each 循环的一些细节.与 Java5 发布的其他术语:释放别名泛型,自动封装和可变参数不同,Java开发者对for-each循环的使用比任何其他特性更加频繁,但当问及高级的for-each循环怎样工作,或什么是在for-each循环中使用Collection时的基本需求时,就不是每个人都能够回答的了. 本篇教程和例子旨在通过深入研究for-each 循环

sql 游标循环遍历

原文:sql 游标循环遍历   写存储过程的时候碰到一个需要对数据进行遍历循环操作的问题,最后通过游标解决了,感觉很适用. 1 declare @level varchar(100) 2 declare @uid varchar(100) 3 declare cur cursor--定义一个游标 4 read_only 5 for select egg_code.user_id,egg_prize_level 6 from egg_code inner join egg_prize on egg