最近刚刚接触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
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我