最近刚刚接触MVC不久,因项目中要用到分页,网上找了下资料,最后采用了MvcPager(http://www.webdiyer.com/),支持同步和Ajax异步分页。废话不多说了直接上代码。
一.MvcPager异步
ViewModel:
1
2
3
4
5
6
7
8
9
10
11
|
public class Article { [Display(Name = "信息编号" )] public int ID { get ; set ; } [Display(Name = "信息标题" )] public string Title { get ; set ; } [Display(Name = "信息内容" )] public string Content { get ; set ; } } |
1
2
3
4
|
public class AjaxPager { public PagedList<Article> Articles { get ; set ; } } |
Control:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
/// <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:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
@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 > |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
@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(此处可不增加,直接和异步的共用同一个):
1
2
3
4
5
|
public class MVCPager { //信息列表 public PagedList<Article> Articles { get ; set ; } } |
Control:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/// <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:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
@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 > |
获取测试数据方法(共用):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
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)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/xiaoxiaocainia/p/5563633.html