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

发布于 2020-11-18|标签javascript
复制链接
摘记: 在web开发中经常会遇到一览画面中每一条记录前都带一个复选框,点击后选中该条记录进行删除、修改、查看等操作。修改和查看都是获取一条记录的id值后传递到后台进行查询获取该记录对象的各种属性值,再显示到画面上。我说的重点是选中多条记录后进行批量删除,如何获取多条记录的id ..
在web开发中经常会遇到一览画面中每一条记录前都带一个复选框,点击后选中该条记录进行删除、修改、查看等操作。修改和查看都是获取一条记录的id值后传递到后台进行查询获取该记录对象的各种属性值,再显示到画面上。我说的重点是选中多条记录后进行批量删除,如何获取多条记录的id值是问题的关键。首先是在jsp页面中全选中复选框的方法。代码如下: ```javascript 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 0) { var i = 0; for (i = 0; i 调用该方法的jsp代码: ```javascript ``` 其中,chooseFaqId是复选框的name属性值,checkAll是表头复选框的name属性值。前台具体执行批处理的js代码,需要对选中的记录id值用逗号分隔,删除批处理方法代码如下: ```javascript 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值 ```java final String ids = this.getRequest().getParameter("chooseFaqId"); ``` 原先获取选中的一组id采用的是以下方式: ```java final String ids = this.getRequest().getParameterValues("chooseFaqId"); ``` 这样可以直接得到一个字符串数组,不需要进行任何编辑操作。后来由于何种原因改成现在的方式有点记不清了。最后是后台BO层执行删除的代码: ```java /** * 根据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提交方式,点击批量删除按钮后,首先判断用户是否至少选中了记录,否则弹出提示消息。选中后点击删除按钮执行后台方法。如果执行操作失败弹出操作失败消息框。
冀ICP备17029012号-4 | 版权所有©鲍亚龙 |免责声明  | GIF图库  | NUXT版