亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在MVC中使用MvcPager實現分頁

發布時間:2021-03-31 15:55:19 來源:億速云 閱讀:111 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關怎么在MVC中使用MvcPager實現分頁,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

一.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 >
 @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 >
 @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;
 }
 }

關于怎么在MVC中使用MvcPager實現分頁就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

固镇县| 米脂县| 秦皇岛市| 淮北市| 阿巴嘎旗| 马尔康县| 兰考县| 嘉义县| 措美县| 漳州市| 灯塔市| 陆河县| 马鞍山市| 错那县| 石城县| 格尔木市| 南阳市| 遂宁市| 景泰县| 红安县| 赤水市| 沅江市| 宜宾县| 汉寿县| 神农架林区| 庄浪县| 外汇| 甘德县| 静乐县| 奎屯市| 施秉县| 信宜市| 顺平县| 屏山县| 呼和浩特市| 肃北| 荔浦县| 高清| 定陶县| 桐梓县| 东乡族自治县|