MVC分页之MvcPager使用详解

最近刚刚接触MVC不久,因项目中要用到分页,网上找了下资料,最后采用了MvcPager(http://www.webdiyer.com/),支持同步和Ajax异步分页。废话不多说了直接上代码。

一.MvcPager异步
 ViewModel:

 public class Article
 {
 [Display(Name = "信息编号")]
 public int ID { get; set; }

 [Display(Name = "信息标题")]
 public string Title { get; set; }

 [Display(Name = "信息内容")]
 public string Content { get; set; }
 }
 public class AjaxPager
 {
 public PagedList<Article> Articles { get; set; }
 }

Control:

/// <summary>
 /// 异步分页测试
 /// </summary>
 /// <param name="id">pageIndex</param>
 /// <param name="key">关键字</param>
 /// <returns></returns>
 public ActionResult AjaxPaging(int? id = 1, string key = null)
 {
  int totalCount = 0;
  int pageIndex = id ?? 1;
  int pageSize = 2;
  List<Article> infoList = new SoleFuDAL.MyTest().GetArticleList(key, pageSize, (pageIndex - 1) * 2, out totalCount);
  PagedList<Article> InfoPager = infoList.AsQueryable().OrderByDescending(o => o.ID).ToPagedList(pageIndex, pageSize);
  InfoPager.TotalItemCount = totalCount;
  InfoPager.CurrentPageIndex = (int)(id ?? 1);

  Models.MyTest.AjaxPager model = new Models.MyTest.AjaxPager();
  model.Articles = InfoPager;
  if (Request.IsAjaxRequest())
  {
  return PartialView("_ArticleList", model);
  }
  return View(model);
 }

View:

@model soulefu_manage.Models.MyTest.AjaxPager
@using Webdiyer.WebControls.Mvc;

<!DOCTYPE html>

<html>
<head>
 <meta name="viewport" content="width=device-width" />
 <title>MVCPager-AjaxPaging</title>
 <link href="~/Content/pagerstyles.css" rel="stylesheet" />
 <link href="~/Content/bootstrap.css" rel="stylesheet" />
</head>
<body>
 <div style="padding: 15px;">
 @using (Html.BeginForm("AjaxPaging", "MyTest", new RouteValueDictionary { { "id", "" } }, FormMethod.Get))
 {
  @Html.Label("关键字:") <input name="key" value="@Request.QueryString["key"]" /><input type="submit" value="查询" />
 }

 @*分页Table*@
 @{ Html.RenderPartial("_ArticleTable"); }

 <div class="text-center">
  @Ajax.Pager(Model.Articles, new PagerOptions
  {
  PageIndexParameterName = "id",
  FirstPageText = "首页",
  PrevPageText = "上一页",
  NextPageText = "下一页",
  LastPageText = "末页",
  NumericPagerItemCount = 5,
  ContainerTagName = "ul",
  CssClass = "pagination",
  CurrentPagerItemTemplate = "<li class=\"active\"><a href=\"#\">{0}</a></li>",
  DisabledPagerItemTemplate = "<li class=\"disabled\"><a>{0}</a></li>",
  PagerItemTemplate = "<li>{0}</li>"
  }).AjaxOptions(a => a.SetUpdateTargetId("articles"))
 </div>
 </div>
</body>
</html>
@model soulefu_manage.Models.MyTest.AjaxPager

<table class="table table-bordered table-striped">
 <tr>
 <th class="nowrap">序号</th>
 <th>
  标题
 </th>
 <th>
  内容
 </th>
 </tr>
 @foreach (var item in Model.Articles)
 {
 <tr>
  <td>@Html.DisplayFor(model => item.ID)</td>
  <td>
  @Html.DisplayFor(modelItem => item.Title)
  </td>
  <td>
  @Html.DisplayFor(modelItem => item.Content)
  </td>
 </tr>
 }
</table>

二.MvcPager同步
  ViewModel(此处可不增加,直接和异步的共用同一个):

 public class MVCPager
 {
 //信息列表
 public PagedList<Article> Articles { get; set; }
 }

Control:

 /// <summary>
 /// 同步分页测试
 /// </summary>
 /// <param name="id">pageIndex</param>
 /// <param name="key">关键字</param>
 /// <returns></returns>
 public ActionResult MVCPager(int? id = 1, string key = null)
 {
  int totalCount = 0;
  int pageIndex = id ?? 1;
  int pageSize = 2;
  List<Article> infoList = new SoleFuDAL.MyTest().GetArticleList(key, pageSize, (pageIndex - 1) * 2, out totalCount);
  PagedList<Article> InfoPager = infoList.AsQueryable().OrderByDescending(o => o.ID).ToPagedList(pageIndex, pageSize);
  InfoPager.TotalItemCount = totalCount;
  InfoPager.CurrentPageIndex = (int)(id ?? 1);

  //数据组装到viewModel
  Models.MyTest.MVCPager model = new Models.MyTest.MVCPager();
  model.Articles = InfoPager;
  return View(model);
 }

View:

@model soulefu_manage.Models.MyTest.MVCPager
@using Webdiyer.WebControls.Mvc;

<!DOCTYPE html>

<html>
<head>
 <meta name="viewport" content="width=device-width" />
 <title>MVCPager</title>
 <link href="~/Content/pagerstyles.css" rel="stylesheet" />
 <link href="~/Content/bootstrap.css" rel="stylesheet" />
</head>
<body>
 <div style="padding:15px;">
 @using (Html.BeginForm("MVCPager", "MyTest", new RouteValueDictionary { { "id", "" } }, FormMethod.Get))
 {
  @Html.Label("关键字:")<input name="key" value="@Request.QueryString["key"]" /><input type="submit" value="查询" />
 }

 <table class="table table-bordered table-striped">
  <tr>
  <th>编号</th>
  <th>标题</th>
  <th>内容</th>
  </tr>
  @foreach (var info in Model.Articles)
  {
  <tr>
   <td>@Html.DisplayFor(model => info.ID)</td>
   <td>@Html.DisplayFor(model => info.Title)</td>
   <td>@Html.DisplayFor(model => info.Content)</td>
  </tr>
  }
 </table>

 <div class="text-center">
  <nav>
  @Html.Pager(Model.Articles, new PagerOptions
  {
   PageIndexParameterName = "id",
   FirstPageText = "首页",
   PrevPageText = "上一页",
   NextPageText = "下一页",
   LastPageText = "末页",
   ContainerTagName = "ul",
   CssClass = "pagination",
   CurrentPagerItemTemplate = "<li class=\"active\"><a href=\"#\">{0}</a></li>",
   DisabledPagerItemTemplate = "<li class=\"disabled\"><a>{0}</a></li>",
   PagerItemTemplate = "<li>{0}</li>",
   Id = "bootstrappager"
  })
  </nav>
 </div>
 </div>
</body>
</html>

获取测试数据方法(共用):

 public class MyTest
 {
 /// <summary>
 /// 获取测试数据
 /// </summary>
 /// <param name="key"></param>
 /// <param name="PageSize"></param>
 /// <param name="CurrentCount"></param>
 /// <param name="TotalCount"></param>
 /// <returns></returns>
 public List<Article> GetArticleList(string key, int PageSize, int CurrentCount, out int TotalCount)
 {
  string tabName = string.Format("Article");
  string strWhere = " 1=1";
  if (!string.IsNullOrEmpty(key))
  {
  //SQL关键字过滤 包含关键字则不拼接SQL
  if (!SqlInjection.GetString(key))
  {
   strWhere += string.Format(" AND (Title LIKE '%{0}%' OR Content LIKE '%{0}%')", key);
  }
  }
  string Order = string.Format("ID ASC");
  DataSet ds = SqlHelper.GetList(SqlHelper.connStr, Order, PageSize, CurrentCount, tabName, strWhere, out TotalCount);
  List<Article> list = new List<Article>();
  if (ds != null && ds.Tables.Count > 0)
  {
  foreach (DataRow dr in ds.Tables[0].Rows)
  {
   Article model = new Article();
   model.ID = Convert.ToInt32(dr["ID"]);
   model.Title = dr["Title"].ToString();
   model.Content = dr["Content"].ToString();
   list.Add(model);
  }
  }
  return list;
 }
 }

效果图:(需要引用CSS)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • ASP.NET MVC 5使用X.PagedList.Mvc进行分页教程(PagedList.Mvc)

    ASP.NET MVC中进行分页的方式有多种,但在NuGet上使用最广泛的就是用PagedList.X.PagedList.Mvc进行分页.(原名为:PagedList.Mvc,但是2014年开始,作者将项目名称改名字为"X.PagedList.Mvc"),用这个插件的话会非常便利,大家可以试试,接下来将给大家讲下如何安装这个NuGet插件. ASP.NET MVC 5使用X.PagedList.Mvc进行分页教程(原名为PagedList.Mvc) 1.工具--NuGet 程序包管理

  • MVC+jQuery.Ajax异步实现增删改查和分页

    本文实例为大家分享了MVC+jQuery.Ajax异步实现增删改查和分页的具体代码,供大家参考,具体内容如下 1.Model层代码 using System; using System.Data; using System.Configuration; using System.Linq; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; usin

  • ASP.NET MVC4 HtmlHelper扩展类,实现分页功能

    1.扩展HtmlHelper类方法ShowPageNavigate public static HtmlString ShowPageNavigate(this HtmlHelper htmlHelper, int currentPage, int pageSize, int totalCount) { var redirectTo = htmlHelper.ViewContext.RequestContext.HttpContext.Request.Url.AbsolutePath; page

  • 基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询

    前言 基于SpringMVC+Bootstrap+DataTables实现数据表格服务端分页.模糊查询(非DataTables Search),页面异步刷新. 说明:sp:message标签是使用了SpringMVC国际化 效果 DataTable表格 关键字查询 自定义关键字查询,非DataTable Search 代码 HTML代码 查询条件代码 <!-- 查询.添加.批量删除.导出.刷新 --> <div class="row-fluid"> <di

  • MVC生成页码选择器返回HTML代码详解

    我主要讲此代码用于MVC的分布页. 先看最终效果最终效果: 样式为bootstrap3中的分页"pagination",如果不使用bootstrap单独提出来并不大 页码生成代码为: public string GetPaginationHtml(PaginationViewModel p) { var PageNum = p.Page;//当前页码(页码从1开始) var PageCount = p.PageCount;//总页数 var ItemCount = p.ItemCoun

  • SpringMvc+Mybatis+Pagehelper分页详解

    最近公司需要做一个告警页面的功能,需要分页,查了很多资料发现PageHelper比较合适 故写一篇从零开始的PageHelper使用的教程,也记录下忙活一天的东西 1.首先需要在项目中添加PageHelper的依赖,这里我用的Maven添加 <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>

  • springmvc 分页查询的简单实现示例代码

    目前较常用的分页实现办法有两种: 1.每次翻页都修改SQL,向SQL传入相关参数去数据库实时查出该页的数据并显示. 2.查出数据库某张表的全部数据,再通过在业务逻辑里面进行处理去取得某些数据并显示. 对于数据量并不大的简单的管理系统而言,第一种实现方法相对来说容易使用较少的代码实现分页这一功能,本文也正是为大家介绍这种方法: 代码片段: 1,Page.java package com.cm.contract.common; import org.apache.commons.lang.Strin

  • Java简单实现SpringMVC+MyBatis分页插件

    1.封装分页Page类 package com.framework.common.page.impl; import java.io.Serializable; import com.framework.common.page.IPage; /** * * * */ public abstract class BasePage implements IPage, Serializable { /** * */ private static final long serialVersionUID

  • ASP.NET MVC分页和排序功能实现

    分页和排序,应该是软件开发中,需要必知必会的技能了,对于分页,网上很多教程,当然,别人终究是别人的,只有自己理解,会了,并且吸收之后,再用自己的语言,传授出来,这才是硬道理.好了,废话说多了.现在我们进入正题: 这里,我打算使用EF Code-First方式分页控件就是用PagedList.MVC,来做分页,对于排序,实现的思路是,加载数据出来之后,默认是升序排序,然后我们点击一下相应的列标题,就按照该字段降序排序,查数据.思路明确了,就开始干吧! 1.首先新建一个空白的MVC项目,在Model

  • 超好用轻量级MVC分页控件JPager.Net

    JPager.Net  MVC好用的轻量级分页控件,好用到你无法想象,轻量到你无法想象. JPager.Net  MVC好用的轻量级分页控件,实现非常简单,使用也非常简单. JPager.Net  MVC好用的轻量级分页控件,代码精心推敲,经多人反复建议修改,最终成型使用中.非常好用分享给大家.源代码一共放出来.先上个效果图: JPager.Net  MVC好用的轻量级分页控件JPager.Net .dll核心代码 PagerInBase.cs namespace JPager.Net { //

随机推荐