全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ASP.Net MVC+Data Table实现分页+排序功能的方法

本文实例讲述了ASP.Net MVC+Data Table实现分页+排序功能的方法。分享给大家供大家参考,具体如下:

实现思路:

使用datatable内置的分页,排序
使用attribute+反射来控制需要排序和显示的字段以及顺序
分离排序和显示逻辑
若要添加搜索逻辑只需要传递搜索的字段到后端即可(js初始化时把"searching": false拿掉)。

View :

@using BCMS.BusinessLogic
@using BCMS.BusinessLogic.Models
@model List<BusCaptainObj>
<table id="tblData" class="table table-striped">
  <thead>
    <tr class="data-list">
      <th style="width:10%;">@Html.DisplayNameFor(model => model.First().PersNo)</th>
      <th style="width:30%;">@Html.DisplayNameFor(model => model.First().Personnel_Name)</th>
      <th style="width:20%;">@Html.DisplayNameFor(model => model.First().Position)</th>
      <th style="width:20%;">@Html.DisplayNameFor(model => model.First().Interchange)</th>
      <th style="width:20%;">Action</th>
    </tr>
  </thead>
</table>
@section scripts {
  <script type="text/javascript">
     @{
       var columns = DataTableHelper.DisplayColumns<BusCaptainObj>();
     }
    $(document).ready(function () {
      $('#tblData').dataTable({
        "processing": true,
        "serverSide": true,
        "searching": false,
        "stateSave": true,
        "oLanguage": { "sInfoFiltered": "" },
        "ajax": {
          "url": @Url.Action("GetJsonData"),
          "type": "GET"
        },
        "columns": [
          { "data": "@columns[0]" },
          { "data": "@columns[1]" },
          { "data": "@columns[2]" },
          { "data": "@columns[3]" },
          {
            "data": "@columns[0]",
            "orderable": false,
            "searchable": false,
            "render": function (data, type, full, meta) {
              if (type === 'display') {
                return GetDetailButton("/BusCaptain/Detail?bcId=", data) + GetInfoButton("/Telematics?bcId=", data, "Performance");
              } else { return data; }
            }
          }
        ],
        "order": [[0, "asc"]]
      });
    });
  </script>
}

Controller :

public ActionResult GetJsonData(int draw, int start, int length)
{
  string search = Request.QueryString[DataTableQueryString.Searching];
  string sortColumn = "";
  string sortDirection = "asc";
  if (Request.QueryString[DataTableQueryString.OrderingColumn] != null)
  {
    sortColumn = GetSortColumn(Request.QueryString[DataTableQueryString.OrderingColumn]);
  }
  if (Request.QueryString[DataTableQueryString.OrderingDir] != null)
  {
    sortDirection = Request.QueryString[DataTableQueryString.OrderingDir];
  }
  DataTableData dataTableData = new DataTableData();
  dataTableData.draw = draw;
  int recordsFiltered = 0;
  dataTableData.data = BusCaptainService.Instance.SearchMyBuscaptains(User.Identity.Name, out recordsFiltered, start, length, sortColumn, sortDirection, search).Data;
  dataTableData.recordsFiltered = recordsFiltered;
  return Json(dataTableData, JsonRequestBehavior.AllowGet);
}
public string GetSortColumn(string sortColumnNo)
{
  var name = DataTableHelper.SoringColumnName<BusCaptainObj>(sortColumnNo);
  return name;
}
public class DataTableData
{
  public int draw { get; set; }
  public int recordsFiltered { get; set; }
  public List<BusCaptainObj> data { get; set; }
}

Model :

class XXX{
...
  [DisplayColumn(0)]
    [SortingColumn(0)]
    public int? A { get; set; }
    [DisplayColumn(1)]
    [SortingColumn(1)]
    public string B { get; set; }
...
}

Helper class :

public class SortingColumnAttribute : Attribute
{
    public int Index { get; }
    public SortingColumnAttribute(int index)
    {
      Index = index;
    }
}
public class DisplayColumnAttribute : Attribute
{
    public int Index { get; }
    public DisplayColumnAttribute(int index)
    {
      Index = index;
    }
}
public static class DataTableQueryString
{
    public static string OrderingColumn = "order[0][column]";
    public static string OrderingDir = "order[0][dir]";
    public static string Searching = "search[value]";
}
public static class DataTableHelper
{
    public static IList<string> DisplayColumns<T>()
    {
      var result = new Dictionary<int, string>();
      var props = typeof(T).GetProperties();
      foreach (var propertyInfo in props)
      {
        var propAttr =
          propertyInfo
            .GetCustomAttributes(false)
            .OfType<DisplayColumnAttribute>()
            .FirstOrDefault();
        if (propAttr != null)
        {
          result.Add(propAttr.Index,propertyInfo.Name);
        }
      }
      return result.OrderBy(x => x.Key).Select(x => x.Value).ToList();
    }
    public static string SoringColumnName<T>(string columnIndex)
    {
      int index;
      if (!int.TryParse(columnIndex, out index))
      {
        throw new ArgumentOutOfRangeException();
      }
      return SoringColumnName<T>(index);
    }
    public static string SoringColumnName<T>(int index)
    {
      var props = typeof(T).GetProperties();
      foreach (var propertyInfo in props)
      {
        var propAttr =
          propertyInfo
            .GetCustomAttributes(false)
            .OfType<SortingColumnAttribute>()
            .FirstOrDefault();
        if (propAttr != null && propAttr.Index == index)
        {
          return propertyInfo.Name;
        }
      }
      return "";
    }
}

Query:

...
var query = context.BusCaptains
            .Where(x => ...)
            .OrderByEx(sortDirection, sortField)
            .Skip(start)
            .Take(pageSize);
...

LINQ Helper :

...
public static IQueryable<T> OrderByEx<T>(this IQueryable<T> q, string direction, string fieldName)
    {
      try
      {
        var customProperty = typeof(T).GetCustomAttributes(false).OfType<ColumnAttribute>().FirstOrDefault();
        if (customProperty != null)
        {
          fieldName = customProperty.Name;
        }
        var param = Expression.Parameter(typeof(T), "p");
        var prop = Expression.Property(param, fieldName);
        var exp = Expression.Lambda(prop, param);
        string method = direction.ToLower() == "asc" ? "OrderBy" : "OrderByDescending";
        Type[] types = new Type[] {q.ElementType, exp.Body.Type};
        var mce = Expression.Call(typeof(Queryable), method, types, q.Expression, exp);
        return q.Provider.CreateQuery<T>(mce);
      }
      catch (Exception ex)
      {
        _log.ErrorFormat("error form OrderByEx.");
        _log.Error(ex);
        throw ;
      }
    }
...

更多关于asp.net相关内容感兴趣的读者可查看本站专题:《asp.net优化技巧总结》、《asp.net字符串操作技巧汇总》、《asp.net操作XML技巧总结》、《asp.net文件操作技巧汇总》、《asp.net ajax技巧总结专题》及《asp.net缓存操作技巧总结》。

希望本文所述对大家asp.net程序设计有所帮助。


# ASP.Net  # MVC  # Data  # Table  # 分页  # 排序  # Asp.Net MVC 分页、检索、排序整体实现代码  # ASP.NET MVC分页和排序功能实现  # ASP.NET MVC 5使用X.PagedList.Mvc进行分页教程(PagedList.Mvc  # ASP.NET MVC4 HtmlHelper扩展类  # 实现分页功能  # ASP.NET MVC4 Razor模板简易分页效果  # ASP.NET同步分页MvcPager使用详解  # asp.net MVC分页代码分享  # ASP.NET MVC分页的实现方法  # ASP.NET MVC分页控件  # 操作技巧  # 相关内容  # 感兴趣  # 给大家  # 只需要  # 更多关于  # 所述  # 若要  # 程序设计  # 射来  # 拿掉  # 后端  # 讲述了  # DisplayColumns  # document  # ready  # var  # columns  # DataTableHelper 


相关文章: 建站之星安装需要哪些步骤及注意事项?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  如何使用Golang table-driven基准测试_多组数据测量函数效率  浅析上传头像示例及其注意事项  佛山企业网站制作公司有哪些,沟通100网上服务官网?  建站主机选购指南:核心配置优化与品牌推荐方案  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  如何快速启动建站代理加盟业务?  如何快速生成凡客建站的专业级图册?  网页设计网站制作软件,microsoft office哪个可以创建网页?  C#怎么创建控制台应用 C# Console App项目创建方法  建站之星导航菜单设置与功能模块配置全攻略  常州企业建站如何选择最佳模板?  公司网站的制作公司,企业网站制作基本流程有哪些?  c# 在ASP.NET Core中管理和取消后台任务  建站主机如何选?性能与价格怎样平衡?  如何选择服务器才能高效搭建专属网站?  如何基于云服务器快速搭建个人网站?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  建站主机空间推荐 高性价比配置与快速部署方案解析  建站VPS能否同时实现高效与安全翻墙?  css网站制作参考文献有哪些,易聊怎么注册?  建站之星后台密码遗忘?如何快速找回?  如何高效利用200m空间完成建站?  平台云上自助建站如何快速打造专业网站?  建站为何优先选择香港服务器?  如何在香港免费服务器上快速搭建网站?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  php8.4新语法match怎么用_php8.4match表达式替代switch【方法】  网站制作壁纸教程视频,电脑壁纸网站?  建站之星如何实现PC+手机+微信网站五合一建站?  建站主机解析:虚拟主机配置与服务器选择指南  网站app免费制作软件,能免费看各大网站视频的手机app?  如何在建站之星网店版论坛获取技术支持?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何零成本快速生成个人自助网站?  建站之星2.7模板快速切换与批量管理功能操作指南  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  建站之星与建站宝盒如何选择最佳方案?  建站之星伪静态规则如何正确配置?  建站之星代理商如何保障技术支持与售后服务?  高端建站如何打造兼具美学与转化的品牌官网?  如何通过虚拟主机空间快速建站?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  高防服务器租用首荐平台,企业级优惠套餐快速部署  网站设计制作公司地址,网站建设比较好的公司都有哪些?  建站主机选虚拟主机还是云服务器更好?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  nginx修改上传文件大小限制的方法 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。