一览画面点击复选框获后如何获取多个id值
来源:互联网 发布:bldeo.js插件怎么使用 编辑:程序博客网 时间:2024/05/01 23:34
在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值
- angular:如何获取多个复选框的id
- js 如何在多个按钮中获取点击按钮的id值
- js 如何在多个按钮中获取点击按钮的id值
- 有关复选框的操作,如何获取多选id,
- 获取多个复选框的值
- 获取多个复选框值
- 获取多个复选框的值
- js 在多个按钮中获取点击按钮的id值
- PHP 获取同一个name多个复选框的值
- Android简单获取多个复选框的值
- AngularJS:表格中选择了多个复选框后如何通过点击提交按钮将复选框选中的数据提取出来
- jquery如何获取复选框的值
- 多个checkbox复选框触发点击事件
- VC中如何获取鼠标点击处控件的ID
- 安卓中如何一次性获取多个控件id(for循环进行获取)
- PHP获取多个同名复选框的值的处理(完整正确版本)
- PHP利用隐藏域获取多个同名复选框的值
- **Apache整合 Tomcat实例
- Android Support Package r7 发布
- fedora 15 NFS 配置
- linux下解压缩大全
- 面向程序员的数据库访问性能优化法则
- 一览画面点击复选框获后如何获取多个id值
- atl com网页搜集
- iOS开发知识点汇集一
- Java 读取配置文件方案
- iPhone开发之SQLite的使用
- redhat enterprise linux 5 scim相关问题
- URL, URN, URI, IRI
- PROFInet与现场总线的集成应用
- pjsip消息在模块与实例间的流动