最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Asp.net MVC 中利用jquery datatables 实现数据分页显示功能

来源:懂视网 责编:小采 时间:2020-11-27 22:35:33
文档

Asp.net MVC 中利用jquery datatables 实现数据分页显示功能

Asp.net MVC 中利用jquery datatables 实现数据分页显示功能:1、Controller中的方法代码如下: 由于方法中的存储过程没有带分页参数,所以还可以有继续优化的空间。 /// <summary> /// 获取测点列表 /// </summary> /// <returns></returns> [HttpPost] p
推荐度:
导读Asp.net MVC 中利用jquery datatables 实现数据分页显示功能:1、Controller中的方法代码如下: 由于方法中的存储过程没有带分页参数,所以还可以有继续优化的空间。 /// <summary> /// 获取测点列表 /// </summary> /// <returns></returns> [HttpPost] p

1、Controller中的方法代码如下:

由于方法中的存储过程没有带分页参数,所以还可以有继续优化的空间。

/// <summary>
 /// 获取测点列表
 /// </summary>
 /// <returns></returns>
 [HttpPost]
 public JsonResult GetMeasurePointList(string TreeID, string TreeType, int sEcho, int iDisplayStart, int iDisplayLength)
 {
 DataTable dtResult = new DataTable();
 string sql = string.Format("EXEC P_GET_ZXJG_TagList '{0}','{1}'", TreeID, TreeType);
 dtResult = QuerySQL.GetDataTable(sql);
 dtResult.Columns.Add("XuHao", typeof(string));
 dtResult.Columns.Add("StrValueTime", typeof(string));
 for (int i = 0; i < dtResult.Rows.Count; i++)
 {
 dtResult.Rows[i]["XuHao"] = (i + 1).ToString();
 dtResult.Rows[i]["StrValueTime"] = Convert.ToDateTime(dtResult.Rows[i]["F_ValueTime"]).ToString("yyyy-MM-dd HH:mm:ss");
 }
 int iTotalRecords = 0;
 int iTotalDisplayRecords = 0;
 List<DataRow> queryList = dtResult.AsEnumerable().ToList();
 iTotalRecords = queryList.Count();
 queryList = queryList.Skip(iDisplayStart).Take(iDisplayLength).ToList();
 iTotalDisplayRecords = queryList.Count();
 var temp = from p in queryList
 select new
 {
 XuHao = p.Field<string>("XuHao").ToString(),
 F_Description = p.Field<string>("F_Description").ToString(),
 StrValueTime = p.Field<string>("StrValueTime").ToString(),
 F_Value = p.Field<decimal>("F_Value").ToString(),
 F_Unit = p.Field<string>("F_Unit").ToString(),
 F_AlmLow = p.Field<decimal>("F_AlmLow").ToString(),
 F_AlmUp = p.Field<decimal>("F_AlmUp").ToString()
 };
 return Json(new
 {
 draw = sEcho,
 recordsFiltered = iTotalRecords,
 recordsTotal = iTotalDisplayRecords,
 data = temp.ToList()
 }, JsonRequestBehavior.AllowGet);
 }

2、cshtml视图页面中代码如下:

function InitData() {
 var dataTable = $('#tbMeasurePointList').DataTable({
 "scrollY": "hidden",
 "scrollCollapse": false,
 "dom": 'tr<"bottom"lip><"clear">',
 language: {
 lengthMenu: '',//左上角的分页大小显示。
 search: '<span class="label label-success">搜索:</span>',//右上角的搜索文本,可以写html标签
 loadingRecords: '数据加载中...',
 paginate: {
 //分页的样式内容。
 previous: "上一页",
 next: "下一页",
 first: "",
 last: ""
 },
 zeroRecords: "暂无数据",//table tbody内容为空时,tbody的内容。
 //下面三者构成了总体的左下角的内容。
 info: "<span class='pagesStyle'>总共<span class='recordsStyle'> _TOTAL_ 条,计 _PAGES_ </span>页,当前显示 _START_ -- _END_ 条记录 </span>",//左下角的信息显示,大写的词为关键字。初始_MAX_ 条 
 infoEmpty: "0条记录",//筛选为空时左下角的显示。
 infoFiltered: ""//筛选之后的左下角筛选提示,
 },
 "lengthChange": false,
 "ordering": false,
 "iDisplayLength": 10,
 "searching": false,
 destroy: true, //Cannot reinitialise DataTable,解决重新加载表格内容问题 
 "serverSide": true,
 "sAjaxSource": "@Url.Action("GetMeasurePointList", "OnlineMonitor")",
 "fnServerData": function (sSource, aoData, fnCallback) {
 aoData.push({ "name": "TreeID", "value": $("#hidTreeID").val() });
 aoData.push({ "name": "TreeType", "value": $("#hidTreeType").val() });
 $.ajax({
 "dataType": 'json',
 "type": "POST",
 "url": sSource,
 "data": aoData,
 "success": fnCallback
 });
 },
 "aoColumns": [
 { "mDataProp": "XuHao", "width": "50" },
 { "mDataProp": "F_Description", "width": "400" },
 { "mDataProp": "StrValueTime", "width": "200" },
 { "mDataProp": "F_Value", "width": "100" },
 { "mDataProp": "F_Unit", "width": "100" },
 { "mDataProp": "F_AlmLow", "width": "100" },
 { "mDataProp": "F_AlmUp", "width": "100"}
 ],
 "createdRow": function (row, data, index) {
 $(row).children('td').eq(0).attr('style', 'text-align: center;');
 $(row).children('td').eq(1).attr('style', 'text-align: left;');
 $(row).children('td').eq(2).attr('style', 'text-align: center;');
 $(row).children('td').eq(3).attr('style', 'text-align: right;');
 $(row).children('td').eq(4).attr('style', 'text-align: center;');
 $(row).children('td').eq(5).attr('style', 'text-align: right;');
 $(row).children('td').eq(6).attr('style', 'text-align: right;');
 }
 });
 }

3、实际显示效果如下图所示:

以上所述是小编给大家介绍的Asp.net MVC 中利用jquery datatables 实现数据分页显示,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Asp.net MVC 中利用jquery datatables 实现数据分页显示功能

Asp.net MVC 中利用jquery datatables 实现数据分页显示功能:1、Controller中的方法代码如下: 由于方法中的存储过程没有带分页参数,所以还可以有继续优化的空间。 /// <summary> /// 获取测点列表 /// </summary> /// <returns></returns> [HttpPost] p
推荐度:
标签: 分页 mvc ASP.NET
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top