jsp打印checkbox多选_一览画面点击复选框后获取多个id值的方法

本文介绍了在web开发中,如何在JSP页面通过复选框实现多条记录的选择,并批量删除。关键在于利用JavaScript处理全选、全不选功能,以及使用Ajax提交选中记录的ID到后台。后台接收到ID后,通过HQL执行批量删除操作。文章强调了正确获取和处理多选复选框ID值的重要性。
摘要由CSDN通过智能技术生成

在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代码:

其中,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("");

return;

}

$.ajax({

type:"POST",

url:"admin/faqManageAction!batchDeleteFaq.action",

data: {chooseFaqId: ids},

dataType: "text",

success:function(html){

if(html=="success"){

jqDialog.alert("",function(){ window.location.href = window.location.href.replace(/#/g,'');

});

} else {

jqDialog.alert("");

}

}

});

});

}

后台获取前台传回的一组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提交方式,点击批量删除按钮后,首先判断用户是否至少选中了记录,否则弹出提示消息。选中后点击删除按钮执行后台方法。如果执行操作失败弹出操作失败消息框。

以上所述是小编给大家介绍的一览画面点击复选框后获取多个id值的方法,希望对大家有所帮助,如果大家想了解更多资讯敬请关注脚本之家网站!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值