简单介绍一下,涉及到的几个知识点:

1.checkbox,多选

2.前台到后台传值,我用的是字符串拼接,到了后台在拆分的方式

3.批量删除的底层实现

效果图

前台view

  1. <table id="list_data" class="easyui-datagrid" style="width:1075px;height:300px" cellpascing="0" cellpadding="0"    ></table>
  1. $(function () {
  2. $('#dg').datagrid({
  3. title: '查询结果',
  4. iconCls: 'icon-view', //图标
  5. width: 100,
  6. height: 'auto',
  7. nowrap: false,
  8. striped: true,
  9. border: true,
  10. collapsible: true, //是否可折叠
  11. fit: true, //自动大小
  12. url: "/EvaluationTemplate/GetData", //传值
  13. remoteSort: false,
  14. pagination: false,  //分页控件
  15. rownumbers: false,  //行号
  16. singleSelect: false, //允许选择多行
  17. selectOnCheck: true,//true勾选会选择行,false勾选不选择行, 1.3以后有此选项。重点在这里
  18. checkOnSelect: true, //true选择行勾选,false选择行不勾选, 1.3以后有此选项
  19. columns: [[
  20. { field: 'ck', checkbox: true, width: '30' },  //复选框
  21. { field: 'TemplateName', title: '模板名称', width: '100' },  //课程类型名称
  22. ]],
  23. });
  24. });
  1. function deletedata() {
  2. //返回选中多行
  3. var selRow = $('#dg').datagrid('getSelections')
  4. //判断是否选中行
  5. if (selRow.length==0) {
  6. $.messager.alert("提示", "请选择要删除的行!", "info");
  7. return;
  8. }else{
  9. var temID="";
  10. //批量获取选中行的评估模板ID
  11. for (i = 0; i < selRow.length;i++) {
  12. if (temID =="") {
  13. temID = selRow[i].TemplateId;
  14. } else {
  15. temID = selRow[i].TemplateId + "," + temID;
  16. }
  17. }
  18. $.messager.confirm('提示', '是否删除选中数据?', function (r) {
  19. if (!r) {
  20. return;
  21. }
  22. //提交
  23. $.ajax({
  24. type: "POST",
  25. async: false,
  26. url: "/EvaluationTemplate/DelTem?id=" + temID,
  27. data: temID,
  28. success: function (result) {
  29. if (result.indexOf("t") <= 0) {
  30. $('#dg').datagrid('clearSelections');
  31. $.messager.alert("提示", "恭喜您,信息删除成功!", "info");
  32. $('#dg').datagrid('reload');
  33. } else {
  34. $.messager.alert("提示", "删除失败,请重新操作!", "info");
  35. return;
  36. }
  37. }
  38. });
  39. });
  40. }
  41. };

解说:根据本篇博客性质,所以,大家重点看

“  selectOnCheck:true,//true勾选会选择行,false勾选不选择行, 1.3以后有此选项。重点在这里

checkOnSelect: true,//true选择行勾选,false选择行不勾选,1.3以后有此选项        ”这两行代码。听着挺绕,其实就是复选框和选中行的颜色一致。一旦选中,复选框和具体某一行都变。

还有循环写入选中行的模板ID,主要利用选中行,getselections的属性,获取个数,循环写入。

Controller.cs

  1. #region 删除模板
  2. /// <summary>
  3. /// 删除模板,批量删除,返回值是布尔值
  4. /// </summary>
  5. /// <returns>返回值是布尔值</returns>
  6. public bool DelTem()
  7. {
  8. //从前台获取字符串拼接,在这里先不转换成数组
  9. String strTemId= Request.QueryString["id"].ToString();
  10. bool bltem = template.DelTemplate(strTemId);
  11. return bltem;
  12. }
  13. #endregion

解说:controller在这里只是作为一个数据传输的纽带。

服务端

  1. //拆分字符串,放入数组中
  2. string[] strTemplateId = strTemplateIdAll.Split(',');
  3. #region 根据条件删除 void DelBy(Expression<Func<T, bool>> delWhere)
  4. /// <summary>
  5. /// 根据条件删除
  6. /// </summary>
  7. /// <param name="delWhere">删除条件</param>
  8. public void DelBy(Expression<Func<T, bool>> delWhere)
  9. {
  10. //1查询要删除的数据
  11. List<T> listDeleting = MyBaseDbContext.Set<T>().Where(delWhere).ToList();
  12. //2将要删除的数据 用删除方法添加到 EF 容器中
  13. listDeleting.ForEach(u =>
  14. {
  15. MyBaseDbContext.Set<T>().Attach(u);//先附加到 EF容器
  16. MyBaseDbContext.Set<T>().Remove(u);//标识为 删除 状态
  17. });
  18. }
  19. #endregion

解说:依旧是底层类库,底层使用EF,涉及到lambda表达式,批量删除实现原理都是一样的,具体实现自己来做吧。

EasyUI-DataGrid之批量删除的更多相关文章

  1. 【EasyUi DataGrid】批量删除

    DataGrid是我们做网页经常使用到的组件之中的一个,对它的操作也无非是增删改查操作.单条数据的增删改相对来说比較简单.添加.改动能够直接在DataGrid中进行,也能够用弹出框的形式把数据装载在文 ...

  2. 实例:SSH结合Easyui实现Datagrid的批量删除功能

    在我先前的基础上面添加批量删除功能.实现的效果如下 删除成功 通常情况下删除不应该真正删除,而是应该有一个标志flag,但flag=true表示状态可见,但flag=false表示状态不可见,为删除状 ...

  3. easyui datagrid 多行删除问题

    问题: var selected = $("#tbList").datagrid("getSelections"); selected的选中项 会包含上次已删掉 ...

  4. 使用easyui实现列表的批量删除

    使用easyui实现列表的批量删除 首先要做的就是增加一个多选框 <table id="otGrid" nowrap="false" style=&quo ...

  5. asp.net mvc4 easyui datagrid 增删改查分页 导出 先上传后导入 NPOI批量导入 导出EXCEL

    效果图 数据库代码 create database CardManage use CardManage create table CardManage ( ID ,) primary key, use ...

  6. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除)

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除) ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   ...

  7. ASP.NET MVC5+EF6+EasyUI 后台管理系统(82)-Easyui Datagrid批量操作(编辑,删除,添加)

    前言 有时候我们的后台系统表单比较复杂,做过进销存或者一些销售订单的都应该有过感觉 虽然Easyui Datagrid提供了行内编辑,但是不够灵活,但是我们稍微修改一下来达到批量编辑,批量删除,批量添 ...

  8. JAVAEE——BOS物流项目04:学习计划、datagrid、分页查询、批量删除、修改功能

    1 学习计划 1.datagrid使用方法(重要) n 将静态HTML渲染为datagrid样式 n 发送ajax请求获取json数据创建datagrid n 使用easyUI提供的API创建data ...

  9. EasyUI datagrid 删除的时候无法正确找到重复记录row index的问题

    EasyUI datagrid 删除的时候无法正确找到重复记录row index的问题: 如果无法正确找到重复记录的row index,就需要进行注意添加的时候所进行的 操作:如果添加的时候就是添加的 ...

  10. ASP.NET给DataGrid,Repeater等添加全选批量删除等功能

    很多情况下,在管理或者查看列表的时候我们需要很需要“全选”这个功能,这在ASP.NET中是非常容易实现的,下面我就将演示一点小代码实现这一功能.   实现全选的还是js的一个小函数:   [code] ...

随机推荐

  1. [原创] SQLite数据库使用清单(下)

    上文两章对SQLite的功能.语法.和操作进行了介绍,本文讲解SQLite的一些高级语法和操作. 3.

  2. MongoDB_1

    突然想去看下MongoDB的东西,于是有了这篇文章.其实很早以前就看过一些关于NoSql的文章,还记得当时里面有介绍MongoDB的,多瞅了2眼,并且在Window下安装了MongoDB的驱动,小玩了 ...

  3. ASP 调用dll(VB)及封装dll实例

    ASP调用dll及封装dll实例,封装为dll可以提供运行效率,加密代码. 打开VB6,新建ActiveX DLL 2.在工程引用中加入Microsoft Active Server Pages Ob ...

  4. Java如何连接到MySQL数据库的

    下载:mysql-connector-java-5.1.38.tar.gz http://dev.mysql.com/downloads/connector/j/ tar zxvf mysql-con ...

  5. javascript——事件处理

    <script type="text/javascript"> function EventUtil() { var _self = this; ///添加事件 var ...

  6. busybox下mount nfs的命令

    busybox下mount nfs的命令 mount -f nfs -o nolock 10.130.30.2:/nfs/nuc970/rootfs /mnt/test

  7. eclipse中show whitespace characters显示代码空格,TAB,回车 导致代码乱恶心

    Eclipse中show whitespace characters显示回车.空格符. 取消此功能的第二种方式:

  8. 源码来袭!!!基于jquery的ajax分页插件(demo+源码)

    前几天打开自己的博客园主页,无意间发现自己的园龄竟然有4年之久了.可是看自己的博客列表却是空空如也,其实之前也有写过,但是一直没发布(然而好像并没有什么卵用).刚开始学习编程时就接触到博客园,且在博客 ...

  9. 如何学习YII

    我是在Yii的官方wiki上看到这篇文章的.读的第一遍觉得很不错,还有一种想翻译出来的冲动.虽然,本人英文很烂,但是毕竟写了这样多年的代码,估计大概的意思是能有的吧.英文原文:http://www.y ...

  10. gdb小结

    testGdb.c #include<stdio.h> int getSum(int a,int b){ printf("a+b=%d\n",a+b); return ...