JQuery 控件 Datatables 服务器端(.Net)Linq 排序

Datatables 是我个人非常喜欢的一个表格插件,这里介绍服务器模式的一些基本用法:

首先了解datatables服务器模式的API:http://datatables.club/manual/server-side.html

为了方便我截了个图:

前端JS的写法

基本结构如下(我简化了大部分的内容)

function init(){
 $('#table').DataTable(
                    {
                        "dom": "ltip",
                        "serverSide": true,//开启服务器模式
                        "processing": true,
                        "ajax": {
                            "url": "/ControllerName/FunctionName",
                            "type": "POST",
                            "data": {"param": "参数"}
                        },
                        "columns":
                            [
                                { "data": "ZoneName", "title": "列1" },
                                { "data": "BuildingName", "title": "列2" },
                                { "data": "GateName", "title": "列3" } 
                            ],
                        "pageLength": 25//每页多少行
                      }

服务器的写法

例子:参数的获取的

 public JsonResult Get_Data_ByTotal(string param, int draw, int start, int length)
 {

  //首先是参数的获取
  string order_col = Request.Form["order[0][column]"].ToString();//排序的列序号
  string order_way = Request.Form["order[0][dir]"].ToString();//排序的方式asc desc
  string col_name = Request.Form[$"columns[{order_col}][data]"].ToString();//排序的列名称
           
 }

例子:排序

排序非常简单,纯SQL的只需要把上面的参数代入:Order BY col_name order_way 即可。

所以这里想介绍的是Linq的写法,因为我们获取的是字符串因此我们需要引用一个NuGet包

using Linq.Dynamic;

这样就支持字符串写法了:


var res = context.Table.OrderBy(col_name + " " + order_way).ToList();

//或更直观的例子:

var lst = context.Table.OrderBy("Name asc,Id desc").ToList();

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值