MVC分页之MvcPager使用详解

前端技术 2023/09/03 .NET

最近刚刚接触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)

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

本文地址:https://www.stayed.cn/item/7717

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。