一览画面点击复选框后获取多个id值的方法


Posted in Javascript onMay 30, 2016

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

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

Javascript 相关文章推荐
JavaScript对内存分配及管理机制详细解析
Nov 11 Javascript
JavaScript定义类的几种方式总结
Jan 06 Javascript
html的DOM中Event对象onabort事件用法实例
Jan 21 Javascript
JavaScript数据绑定实现一个简单的 MVVM 库
Apr 08 Javascript
jQuery实现带遮罩层效果的blockUI弹出层示例【附demo源码下载】
Sep 14 Javascript
手机端实现Bootstrap简单图片轮播效果
Oct 13 Javascript
详解JavaScript模块化开发
Dec 04 Javascript
react学习笔记之state以及setState的使用
Dec 07 Javascript
element-ui中select组件绑定值改变,触发change事件方法
Aug 24 Javascript
webpack css加载和图片加载的方法示例
Sep 11 Javascript
js字符串处理之绝妙的代码
Apr 05 Javascript
vue+elementUI(el-upload)图片压缩,默认同比例压缩操作
Aug 10 Javascript
js判断复选框是否选中及选中个数的实现代码
May 30 #Javascript
JS控制弹出悬浮窗口(一览画面)的实例代码
May 30 #Javascript
限制复选框最多选择项的实现代码
May 30 #Javascript
Javascript实现通过选择周数显示开始日和结束日的实现代码
May 30 #Javascript
JS组件Bootstrap Table使用实例分享
May 30 #Javascript
Bootstrap table分页问题汇总
May 30 #Javascript
浅析Javascript中bind()方法的使用与实现
May 30 #Javascript
You might like
php实现多张图片上传加水印技巧
2013/04/18 PHP
Win7 64位系统下PHP连接Oracle数据库
2014/08/20 PHP
php网站被挂木马后的修复方法总结
2014/11/06 PHP
php无序树实现方法
2015/07/28 PHP
php 微信开发获取用户信息如何实现
2016/12/13 PHP
PHP+jQuery实现滚屏无刷新动态加载数据功能详解
2017/05/04 PHP
浅谈使用 Yii2 AssetBundle 中 $publishOptions 的正确姿势
2017/11/08 PHP
PHP双向链表定义与用法示例
2018/01/31 PHP
jQuery调用WebService的实现代码
2011/06/19 Javascript
在百度知道团队中快速审批新成员的js脚本
2014/02/02 Javascript
jQuery+ajax实现无刷新级联菜单示例
2015/05/21 Javascript
JavaScript字符串常用的方法
2016/03/10 Javascript
javascript中利用柯里化函数实现bind方法【推荐】
2016/04/29 Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
2016/09/19 Javascript
JavaScript中三个等号和两个等号的区别(== 和 ===)浅析
2016/09/22 Javascript
jquery获取点击控件的绝对位置简单实例
2016/10/13 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
nodejs简单读写excel内容的方法示例
2018/03/16 NodeJs
React中使用UEditor百度富文本的方法
2018/08/22 Javascript
ES10的13个新特性示例(小结)
2019/09/23 Javascript
js前端对于大量数据的展示方式及处理方法
2020/12/02 Javascript
python装饰器实例大详解
2017/10/25 Python
详解Python 实现元胞自动机中的生命游戏(Game of life)
2018/01/27 Python
numpy 计算两个数组重复程度的方法
2018/11/07 Python
使用Python制作新型冠状病毒实时疫情图
2020/01/28 Python
Python新手学习装饰器
2020/06/04 Python
Python 执行矩阵与线性代数运算
2020/08/01 Python
Finishline官网:美国一家领先的运动品牌鞋类、服装零售商
2016/07/20 全球购物
加拿大最大的钻石商店:Peoples Jewellers
2018/01/01 全球购物
德国大型和小型家用电器网上商店:Energeto
2019/05/15 全球购物
上海奥佳笔试题面试题
2016/11/16 面试题
保安自我鉴定范文
2013/12/08 职场文书
优秀学生评语大全
2014/04/25 职场文书
机关领导干部作风整顿整改措施
2014/09/19 职场文书
银行大堂经理培训心得体会
2016/01/09 职场文书
nginx的zabbix 5.0安装部署的方法步骤
2021/07/16 Servers