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

2025-05-29 0 70

JPager.Net MVC好用的轻量级分页控件,好用到你无法想象,轻量到你无法想象。

JPager.Net MVC好用的轻量级分页控件,实现非常简单,使用也非常简单。

JPager.Net MVC好用的轻量级分页控件,代码精心推敲,经多人反复建议修改,最终成型使用中。非常好用分享给大家。源代码一共放出来。先上个效果图:

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

JPager.Net MVC好用的轻量级分页控件JPager.Net .dll核心代码

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

PagerInBase.cs

?

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
namespace JPager.Net

{

/// <summary>

/// 分页基础类

/// </summary>

public class PagerInBase

{

/// <summary>

/// 当前页

/// </summary>

public int PageIndex { get; set; }

/// <summary>

/// 页数

/// </summary>

public int PageSize { get; set; }

//跳过序列中指定数量的元素

public int Skip => (PageIndex - 1) * PageSize;

/// <summary>

/// 请求URL

/// </summary>

public string RequetUrl => System.Web.HttpContext.Current.Request.Url.OriginalString;

/// <summary>

/// 构造函数给当前页和页数初始化

/// </summary>

public PagerInBase()

{

if (PageIndex == 0) PageIndex = 1;

if (PageSize == 0) PageSize = 10;

}

}

}

PagerResult.cs

?

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

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72
using System;

using System.Collections.Generic;

using System.Text;

namespace JPager.Net

{

/// <summary>

/// ULR拼装

/// </summary>

internal static class Exts

{

public static string GetUrl(this string url, int curIndex, int reps)

{

return url.Replace("pageindex=" + curIndex.ToString(), "pageindex=" + reps.ToString());

}

}

/// <summary>

/// 分页核心代码

/// </summary>

/// <typeparam name="T"></typeparam>

public class PagerResult<T>

{

public int Code { get; set; }

public int Total { get; set; }

public IEnumerable<T> DataList { get; set; }

public int PageSize { get; set; }

public int PageIndex { get; set; }

public string RequestUrl { get; set; }

/// <summary>

/// 分页页码Html

/// </summary>

/// <param name="cssClass">默认样式:jpager</param>

/// <returns></returns>

public string PagerHtml(string cssClass="jpager")

{

if (PageIndex == 0) PageIndex = 1;

if (RequestUrl.IndexOf("?", StringComparison.Ordinal) == -1) RequestUrl += "?pageindex=1";

else

if (RequestUrl.IndexOf("&pageindex", StringComparison.Ordinal) == -1&& RequestUrl.IndexOf("?pageindex", StringComparison.Ordinal) == -1) RequestUrl += "&pageindex=1";

var html = new StringBuilder();

html.AppendFormat("<span class='{0}'>", cssClass);

var pageLen = Math.Ceiling((double)Total / PageSize);

html.AppendFormat("<a href='{0}'> 首页 </a>", RequestUrl.GetUrl(PageIndex,1));

html.AppendFormat("<a href='{0}'> 上页 </a>", RequestUrl.GetUrl(PageIndex, PageIndex < 2 ? 1 : PageIndex - 1));

var si = PageIndex <= 6 ? 1 : PageIndex - 5;

var ei = si + 9;

while (si <= pageLen && si <= ei)

html.AppendFormat(

si == PageIndex

? "<a style='color:black;border:none;' href='{0}'> {1} </a>"

: "<a href='{0}'> {1} </a>", RequestUrl.GetUrl(PageIndex, si), si++);

html.AppendFormat("<a href='{0}'> 下页 </a>", RequestUrl.GetUrl(PageIndex, (int)(PageIndex > pageLen - 1 ? pageLen : PageIndex + 1)));

html.AppendFormat("<a href='{0}'> 尾页 </a>",

Math.Abs(Total) <= 0

? RequestUrl.GetUrl(PageIndex, 1)

: RequestUrl.GetUrl(PageIndex, (int) pageLen));

html.Append(@"</span>");

return html.ToString();

}

}

}

使用方法:

HomeController.cs

?

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

57

58

59

60

61
using System;

using System.Collections.Generic;

using System.Linq;

using System.Web.Mvc;

using JPager.Net;

using JPager.Net.Web.Models;

namespace JPager.Net.Web.Controllers

{

public class HomeController : Controller

{

public ActionResult Index(UserParams param)

{

//每页显示的条数默认10

//param.PageSize = 10;

//保存搜索条件

ViewBag.SearchName = param.Name;

ViewBag.SearchAge = param.Age;

//获取数据集合

var list = PageContent();

//根据条件检索

var query = param.Name!=null ?

list.Where(t=>t.Name.Contains(param.Name)).ToList() :

list.ToList();

//分页数据

var data = query.Skip(param.Skip).Take(param.PageSize);

//总页数

var count = query.Count;

var res = new PagerResult<User> { Code = 0, DataList = data, Total = count,

PageSize = param.PageSize,PageIndex = param.PageIndex,RequestUrl = param.RequetUrl};

return View(res);

}

//测试数据

public List<User> PageContent()

{

var list = new List<User>();

for (var t = 0; t < 10000; t++)

{

list.Add(new User

{

Id = t,

Name = "Joye.net"+t.ToString(),

Age = t + 10,

Score = t,

Address = "http://yinrq.cnblogs.com/",

AddTime = DateTime.Now

});

}

return list;

}

}

}

Models文件夹建User.cs和UserParams.cs

User.cs

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17
using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

namespace JPager.Net.Web.Models

{

public class UserParams:JPager.Net.PagerInBase

{

public int Id { get; set; }

public string Name { get; set; }

public int ? Age { get; set; }

public int Score { get; set; }

public string Address { get; set; }

public DateTime AddTime { get; set; }

}

}

UserParams.cs

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14
using System;

namespace JPager.Net.Web.Models

{

public class User

{

public int Id { get; set; }

public string Name { get; set; }

public int Age { get; set; }

public int Score { get; set; }

public string Address { get; set; }

public DateTime AddTime { get; set; }

}

}

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
@model JPager.Net.PagerResult<JPager.Net.Web.Models.User>

@{

ViewBag.Title = "Index";

}

<h2>JPager.Net MVC好用的轻量级分页控件</h2>

<div>

<div>

<form method="get">Name:

<input name="Name" id="Name" />

Age:

<input name="Age" id="Age"/>

<input type="submit" value="查询" />

</form>

</div>

<table>

<tr>

<th>ID</th>

<th>Name</th>

<th>Age</th>

<th>Score</th>

<th>Address</th>

<th>AddTime</th>

</tr>

@foreach (JPager.Net.Web.Models.User item in Model.DataList)

{

<tr>

<td>@item.Id</td>

<td>@item.Name</td>

<td>@item.Age</td>

<td>@item.Score</td>

<td><a href="@item.Address" target="_target">@item.Address</a></td>

<td>@item.AddTime</td>

</tr>

}

</table>

</div>

<div>

@Html.Raw(Model.PagerHtml()) 共 @Model.Total 条

</div>

<script type="text/javascript">

//保持搜索条件

$(function () {

$('#Name').val('@ViewBag.SearchName');

$('#Age').val('@ViewBag.SearchAge');

});

</script>

github:https://github.com/decadestory/JPager.Net

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 超好用轻量级MVC分页控件JPager.Net https://www.kuaiidc.com/100056.html

相关文章

发表评论
暂无评论