ASP.Net MVC+Data Table实现分页+排序功能的方法
发布时间 - 2026-01-11 01:52:38 点击率:次本文实例讲述了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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何生成API文档?(Swagger/OpenAPI教程)
高端云建站费用究竟需要多少预算?
Laravel如何使用Blade模板引擎?(完整语法和示例)
Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】
如何在服务器上三步完成建站并提升流量?
Laravel Docker环境搭建教程_Laravel Sail使用指南
香港服务器WordPress建站指南:SEO优化与高效部署策略
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
如何在七牛云存储上搭建网站并设置自定义域名?
非常酷的网站设计制作软件,酷培ai教育官方网站?
Laravel distinct去重查询_Laravel Eloquent去重方法
JavaScript实现Fly Bird小游戏
JavaScript中的标签模板是什么_它如何扩展字符串功能
Laravel如何实现本地化和多语言支持?(i18n教程)
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
Swift开发中switch语句值绑定模式
Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
C#如何调用原生C++ COM对象详解
如何快速生成可下载的建站源码工具?
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
深圳网站制作平台,深圳市做网站好的公司有哪些?
如何生成腾讯云建站专用兑换码?
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
JavaScript如何操作视频_媒体API怎么控制播放
Laravel集合Collection怎么用_Laravel集合常用函数详解
java中使用zxing批量生成二维码立牌
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
如何在香港免费服务器上快速搭建网站?
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
JS碰撞运动实现方法详解
如何用景安虚拟主机手机版绑定域名建站?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
JavaScript Ajax实现异步通信
如何在宝塔面板创建新站点?
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
如何彻底卸载建站之星软件?
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
如何在景安云服务器上绑定域名并配置虚拟主机?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
如何自定义建站之星模板颜色并下载新样式?
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
公司门户网站制作流程,华为官网怎么做?
Laravel如何实现模型的全局作用域?(Global Scope示例)
下一篇:小红书怎么查商品订单【教程】
下一篇:小红书怎么查商品订单【教程】

