一览画面点击复选框获后如何获取多个id值

原创 2012年03月22日 18:03:57

在web开发中经常会遇到一览画面中每一条记录前都带一个复选框,点击后选中该条记录进行删除、修改、查看等操作。修改和查看都是获取一条记录的id值后传递到后台进行查询获取该记录对象的各种属性值,再显示到画面上。我说的重点是选中多条记录后进行批量删除,如何获取多条记录的id值是问题的关键。首先是在jsp页面中全选中复选框的方法。代码如下:

function checkEvent(name, allCheckId) {   
     var allCk = document.getElementById(allCheckId);   
      if (allCk.checked == true) 
          checkAll(name);   
      else 
          checkAllNo(name);   
   }   
	 
   //全选   
   function checkAll(name) {   
      var names = document.getElementsByName(name);   
      var len = names.length;   
      if (len > 0) {   
         var i = 0;   
       for (i = 0; i < len; i++)   
    	   if(!names[i].disabled){
        	   names[i].checked = true;   
           }
     }   
   }
    //全不选   
   function checkAllNo(name) {
	  var names = document.getElementsByName(name);   
	  var len = names.length;   
	  if (len > 0) {   
	       var i = 0;   
	       for (i = 0; i < len; i++)   
	         names[i].checked = false;   
	     }   
  }

调用该方法的jsp代码:

<input name="checkAll" id ="checkAll" onclick="checkEvent('chooseFaqId','checkAll')"  type="checkbox"/></td>

其中,chooseFaqId是复选框的name属性值,checkAll是表头复选框的name属性值。
前台具体执行批处理的js代码,需要对选中的记录id值用逗号分隔,删除批处理方法代码如下:

function batchDeletechFaq(idStr){
		var ids="'";
		$("input[name='chooseFaqId']").each(function(){
			if(this.checked){
				ids+=this.value+"','"
			}
		});
		ids+="'";
		ids=ids.replace(/,''/g,'');
		if(ids=="''"){
			jqDialog.alert("<s:text name='faqManage.pleaseSelectFaq'/>");
			return;
		}
		$.ajax({   
			 type:"POST",    
			 url:"admin/faqManageAction!batchDeleteFaq.action",    
			 data: {chooseFaqId: ids},    
			 dataType: "text",    
			 success:function(html){     
				if(html=="success"){      
					jqDialog.alert("<s:text name='faqManage.OperationWasSuccessful'/>",function(){       						window.location.href = window.location.href.replace(/#/g,'');       
					});     
				} else {      
					jqDialog.alert("<s:text name='faqManage.OperationFailedPleaseTryLater'/>");     
				}    
			}   
		});  
	});
}


后台获取前台传回的一组id值

final String ids = this.getRequest().getParameter("chooseFaqId");

原先获取选中的一组id采用的是以下方式:

final String ids = this.getRequest().getParameterValues("chooseFaqId");

这样可以直接得到一个字符串数组,不需要进行任何编辑操作。后来由于何种原因改成现在的方式有点记不清了。

最后是后台BO层执行删除的代码:

	/**
	 * 根据ID批量删除FAQ问题
	 * @param faqAnswer
	 * @return
	 */
	public void batchDeleteFaq(final String ids){
		final String hql = "delete from FAQAnswer o where o.id in ("+ids+")";
		faqManagerDao.execute(hql);
	}

总结,我采用的是ajax提交方式,点击批量删除按钮后,首先判断用户是否至少选中了记录,否则弹出提示消息。选中后点击删除按钮执行后台方法。如果执行操作失败弹出操作失败消息框。

checkbox多选框,获取多条数据ID

[javascript] view plain copy //取得所有的复选框对象数组   function GetAllCheckBox() {     var div = docum...
  • liuyangjie_
  • liuyangjie_
  • 2016年12月28日 11:34
  • 879

js中得到checkbox标签选中的信息的id

function addcourse(){     if (checkCheckBox(document.forms[0]) == 0) {             alert("请选择需要添加的...
  • u012406790
  • u012406790
  • 2014年09月12日 13:12
  • 453

多个checkbox 获取选中的 并且把传递的id用逗号隔开(jQuery)

ajax一个入参需要传多个数据,用,分隔怎么处理?例一、 $("#gaipai").click(function(){ var arrs=new Array(); ...
  • qq_39198420
  • qq_39198420
  • 2017年12月16日 10:16
  • 109

有关复选框的操作,如何获取多选id,

原 有关复选框的操作,如何获取多选id,
  • Abubu123
  • Abubu123
  • 2016年06月16日 15:09
  • 5852

有关复选框的操作,如何获取多选id,

原 有关复选框的操作,如何获取多选id,
  • Abubu123
  • Abubu123
  • 2016年06月16日 15:09
  • 5852

点击checkbox使用js取table中tr下td中的各个标签value

http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> http://www.w3.org/1999/xhtml">     ...
  • zunguitiancheng
  • zunguitiancheng
  • 2013年05月29日 13:28
  • 3618

Jquery获取勾选复选框里面的值并且动态添加到一个新的div里面

$(function() { //获取所有复选框 var $xz = $("input[name=check-2]:checked"); $("input:button").click(func...
  • qq_32340877
  • qq_32340877
  • 2017年01月12日 15:27
  • 1234

php获取复选框的值CheckBox的多个值

1html代码 Title 用户名: 密 码: 性别:男 女 ...
  • leiliang520130
  • leiliang520130
  • 2016年04月02日 20:42
  • 226

table点击复选框,随意动态分配表格

  • 2010年04月23日 07:48
  • 15KB
  • 下载

datagridview点击复选框删除

  • 2009年02月20日 10:24
  • 825KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一览画面点击复选框获后如何获取多个id值
举报原因:
原因补充:

(最多只允许输入30个字)