jQuery+SpringMVC中的复选框选择与传值

一、checkbox选择

在jQuery中,选中checkbox通用的两种方式:

$("#cb1").attr("checked","checked");
$("#cb1").attr("checked",true);

对应的jQuery函数,主要完成三个功能:

1、第一个复选框选中或取消选中,则下面的复选框为全选或取消全选;

2、当下面的复选框全部选中时,则将第一个复选框设置为选中,当下面的复选框中有一个没有被选中时,则第一个复选框取消选中;

3、将下面的复选框的id值传递给Controller层,组成id数组,然后调用相应的方法(一般都是删除)。

<script type="text/javascript">    function chgAll(t){//第一个复选框选中或取消选中,则下面的复选框为全选或取消全选;
        $("input[name=‘id‘]").attr(‘checked‘,t.checked);//改变name名为id的input标签内的复选框的checked属性
    }
    function chg(){//当下面的复选框全部选中时,则将第一个复选框设置为选中,当下面的复选框中有一个没有被选中时,则第一个复选框取消选中;
        var ids = $.makeArray($("input[name=‘id‘]"));
        for(var i in ids){
            if(ids[i].checked==false){//如果所有的复选框只要有一个未选中,则第一个复选框不会选中
                $("input[name=‘ids‘]").attr(‘checked‘, false);
                return;
            }
        }
        $("input[name=‘ids‘]").attr(‘checked‘, true);//全部选中的情况下,则第一个复选框选中
    }
    function deleteBatch(){//将下面的复选框的id值传递给Controller层,组成id数组,拼接url到controller层,调用批量删除方法(deleteBatch())方法
        var ids = $.makeArray($("input[name=‘id‘]:checked"));//通过$.makeArray将id放在数组中
        var url = ‘<%basePath%>/web/goodsList/deleteBatch‘;//此url指向controller层的deleteBatch方法,需要id属性
        var flag = true;
        for(var i in ids){//遍历数组
            if(i == 0){
                    url += "?id=" + ids[i].value;//第一个id属性前加?拼接
                    flag = false;
                } else {
                    url += "&id=" + ids[i].value;//后面的id属性前加&拼接
                    flag = false;
                }
            }
        if(flag){//如果没有选中商品
            alert("请选中商品!");
            return;
        }
        if(confirm("确定删除记录吗?")){
            window.location.href = url;//把拼接好的id数组传给页面
        }
        }
</script>

二、在jsp页面中对应的列表:

1、列表中要给表头中的复选框(第一个复选框)设置name名,并调用chgAll(this)方法来实现全选或全不选;

2、table中的复选框设置name名,并调用chg()方法来实现上面的第二个功能;

3、form表单提交时调用deleteBatch()方法

<body>
	<form:form id="uuForm" modelAttribute="goods" 	action="<%basePath%>/web/goodsList/" method="post" >//form表单提交时调用deleteBatch()方法
		<div>	<input  type="button"	onclick="deleteBatch()" value="批量删除" />	</div>
	</form:form>
	<sys:message content="${message}" />
	<table id="cTable" >
		<thead>
			<tr>
			<th><input type="checkbox" name="ids"  onchange="chgAll(this)" /></th>//调用chgAll(this)方法来实现全选或全不选,此处的this指所有复选框对象
				<th>商品编号</th>
				<th>商品标题</th>
			</tr>
		</thead>
		<tbody>
			<c:forEach items="${goods}" var="goods" varStatus="status">
				<tr>
				<td><input type="checkbox"  name="id" value="${goods.goodsId }" onchange="chg()"/></td>//调用chg()方法
					<td>${webGoodsInfo.goodsNo}</td>
					<td>${webGoodsInfo.goodsTitle}</td>
				</tr>
			</c:forEach>
		</tbody>
	</table>

</body>

三、看下spring MCV中的controller代码

@RequestMapping("deleteBatch")//对应jsp页面中的deleteBatch()请求
	public String deleteBatch(Long[] id, RedirectAttributes redirectAttributes){//此处的id为页面中的id值,必须保持一直!!!!
		if(id !=null&&id.length!=0){
			goodsService.deleteBatch(id);
		}
		return "redirect:"+Global.getAdminPath()+"/web/webGoodsInfo/?repage";//重定向到列表页面
	}
}

看下效果:

 

(代码部分我省略了不少,但是今天讲的复选框多选与传值的部分全部无损呈现!)

时间: 2024-12-28 11:19:58

jQuery+SpringMVC中的复选框选择与传值的相关文章

ASP.NET实现弹出框真分页将复选框选择的数据存到数据库中(一)

ASP.NET实现弹出框真分页将复选框选择的数据存到数据库中,这个问题分一下几步走 1.将弹出框真分页后复选框选择的数据保存. 2.将弹出框保存的数据传到父页面上. 3.将数据在父页面上显示. 4.点击保存将信息存入数据库中. 首先来第一步将弹出框真分页后复选框选择的数据保存. 思路很简单就是先真分页,然后在点击下一页的时候扫描这一页所有点击复选框的数据保存到一个变量数组中.下面就是主要代码: ASP代码: <%@ Page Language="C#" AutoEventWire

jquery中input复选框的checked属性

在今日的多选,反选,全选试验中,关于通过jQuery方法来实现复选框的选中与否问题,我有了以下发现: 1.不能通过.css('checked','checked')方法来设置或者获取复选框的checked属性,在控制台打印输出.css('checked'),结果为undefined, 不管在HTML中是否设置了checked='checked'; 2.通过attr添加属性即.attr('checked','abc'),会给HTML中input所在处添加checked='checked'这样的代码

jQuery实现的checkbox复选框全选和全不选效果

jQuery实现的checkbox复选框全选和全不选效果:复选框的全选和全不选效果在代码中非常的常用,尤其在批量处理的需求中更是如此,下面就通过一个代码实例简单介绍一下如何实现此效果,希望能够对需要的朋友有所帮助,代码实例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http:

在php中验证复选框

PHP接收多个同名复选框信息不像ASP那样自动转换成为数组,这给使用带来了一定不便.但是还是有解决办法的,就是利用javascript做一下预处理.多个同名复选框在javascript中还是以数组的形式存在的,所以在表单提交之前可以利用javascript把复选框中的信息组合成一个字符数组赋值给表单中的隐藏元素,然后用PHP中的explode函数解析此数组,这样就可以实现复选框信息的传递了.下面举例说明. 假设有这样一个表单: <form name="form1" id=&quo

QTableView中嵌入复选框CheckBox 的四种方法总结

搜索了一下,QTableView中嵌入复选框CheckBox方法有四种: 第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四种比较适合扩展,它除了可以嵌入复选框,还可以通过paint()绘制其它控件,图片等自定义风格. 第一种方法是:编辑委托法 这种方法直接利用委托中重载createEditor(),激活QCheckBox,这个缺点是必须双击/选中,才能显示CheckBox控件.一般不满足我们实际中的直接显示的需要.可以

jQuery实现checkbox(复选框)选中、全选反选代码

谁都知道 在html 如果一个复选框被选中 是 checked="checked". 但是我们如果用jquery alert($("#id").attr("checked")) 会提示您是true而不是checked 所以很多朋友判断  if($("#id").attr("checked")=="true") 这个是错误的,其实应该是 if($("#id").attr

C# Word中插入复选框选中符号

object fontname = "Wingdings 2";  object uic = true;    doc.Bookmarks.get_Item(ref lblmark).Range.InsertSymbol(-4014, ref fontname, ref uic, ref missing); C# Word中插入复选框选中符号,布布扣,bubuko.com

jQuery 获取 多个 复选框 和 javascript 对比

$('input[name="teams"]:checked').size() 1 // 全选 2 $("#quanteam").bind("click", function () { 3 $("[name = teams]:checkbox").attr("checked", true); 4 }); 5 // 全不选 6 $("#quanteam1").bind("clic

nodetree中 前面复选框禁用插件

nodetree中 前面复选框的去掉插件 extendTreeCheck.js 1 /** 2 * tree方法扩展 3 * 作者:小雪转中雪 4 */ 5 $.extend($.fn.tree.methods, { 6 /** 7 * 激活复选框 8 * @param {Object} jq 9 * @param {Object} target 10 */ 11 enableCheck : function(jq, target) { 12 return jq.each(function(){