asp.net MVC通用分页组件 使用方便 通用性强
asp.net MVC通用分页组件 使用方便 通用性强
该分页控件的显示逻辑:
1 当前页面反色突出显示,链接不可点击
2 第一页时首页链接不可点击

3 最后一页时尾页链接不可点击

4 当前页面左右各显示页码可以设置调节,如果左右一样则居中

5 当左边页码不足时,右侧补充

6 当右侧页面不足时左侧补充

7 总显示页码数为左侧+右侧+1(当前)
组成部分:
1 PageModel 便于向组件传递参数

public class PageModel
{
/// <summary>
/// 数据总条数
/// </summary>
public int DataCount { get; set; }
/// <summary>
/// 当前页码
/// </summary>
public int Page { get; set; }
/// <summary>
/// 每页条数
/// </summary>
public int PageSize { get; set; }
/// <summary>
/// 当前页码左边显示页数
/// </summary>
public int NumsOfLeft { get; set; }
/// <summary>
/// 当前页码右边显示页数
/// </summary>
public int NumsOfRight { get; set; }
/// <summary>
/// 每页允许显示的最大条数
/// 如果PageSize大于MaxPage则以MaxPage为准
/// </summary>
public int MaxPage { get; set; }
/// <summary>
/// 页面前面的URL
/// 比如URL为http://www.chengchenxu.com/1
/// 1为页码,则该属性应该设置为:
/// http://www.chengchenxu/
/// </summary>
public string Url { get; set; }
public PageModel()
{
//设置的默认值
this.PageSize = 10;
this.NumsOfLeft = 4;
this.NumsOfRight = 4;
this.MaxPage = 30;
}

2 分部视图: 这是一个强类型View,最上面的要对应到你的项目的命名空间中.

@model ChengChenXu.com.PageModel.Models.PageModel
<ul class="pagination">
@{
//页码逻辑运算
double d = (double)Model.DataCount / Model.PageSize;
int pageNum = (int)Math.Ceiling(d);
Model.Page = Model.Page < 1 ? 1 : Model.Page;
Model.Page = Model.Page > pageNum ? pageNum : Model.Page;
Model.PageSize = Model.PageSize > Model.MaxPage ? Model.MaxPage : Model.PageSize;
int startNum, endNum;
if (Model.Page > Model.NumsOfLeft)
{
endNum = Model.Page + Model.NumsOfRight;
}
else
{
endNum = Model.Page + Model.NumsOfRight + (Model.NumsOfLeft - Model.Page + 1);
}
if (pageNum - Model.Page >= Model.NumsOfRight)
{
startNum = Model.Page - Model.NumsOfLeft;
}
else
{
startNum = Model.Page - Model.NumsOfLeft - (Model.NumsOfRight - (pageNum - Model.Page));
}
startNum = startNum < 1 ? 1 : startNum;
endNum = endNum > pageNum ? pageNum : endNum;
//END 页码逻辑运算
//开始显示页码
//显示首页
if (pageNum == 1 || Model.Page == 1)
{
<li class="disabled"><a href="#" onclick="return false;">«</a></li>
}
else
{
<li><a href="@Model.Url">«</a></li>
}
//END 显示首页
//显示页码
for (int i = startNum; i <= endNum; i++)
{
if (i == Model.Page)
{
<li class="active"><a href="#" onclick="return false;">@i</a></li>
}
else
{
<li><a href="@Model.Url@i">@i</a></li>
}
}
//END 显示页码
//显示尾页
if (pageNum == 1 || Model.Page == pageNum)
{
<li class="disabled"><a href="#" onclick="return false;">»</a></li>
}
else
{
<li><a href="@Model.Url@pageNum">»</a></li>
}
//END 显示尾页
}
</ul>

使用方法:
1 在需要使用的地方添加以下代码:
第一个参数为分部View的文件名,(要放到Shared文件夹中)
第二个参数为页面使用ViewBag传进来的PageModel对象 注意命名空间和ViewBag的动态标签
@Html.Partial("PagePartial", ViewBag.PageModel as ChengChenXu.com.PageModel.Models.PageModel)
2 在Controller中创建PageModel对象并使用ViewBag传递

public ActionResult Index(int id=1,int pagesize=10)
{
//模拟200条数据
List<string> list = new List<string>();
for (int i = 1; i <= 200; i++)
{
list.Add("第"+i+"条数据");
}
ViewBag.List = list;
//创建PageModel对象
Models.PageModel pm = new Models.PageModel();
pm.DataCount = list.Count;//数据总条数
pm.Page = id;//当前页码
pm.PageSize = pagesize;//每页数量
pm.Url = "/home/index/"; //URL
ViewBag.PageModel = pm; //传递PageModel
return View();
}

生成代码
样式表请自己设计 DEMO中直接使用Bootstrap框架分页样式.

<ul class="pagination">
<li class="disabled"><a href="#" onclick="return false;">«</a></li>
<li class="active"><a href="#" onclick="return false;">1</a></li>
<li><a href="/home/index/2">2</a></li>
<li><a href="/home/index/3">3</a></li>
<li><a href="/home/index/4">4</a></li>
<li><a href="/home/index/5">5</a></li>
<li><a href="/home/index/6">6</a></li>
<li><a href="/home/index/7">7</a></li>
<li><a href="/home/index/8">8</a></li>
<li><a href="/home/index/9">9</a></li>
<li><a href="/home/index/20">»</a></li>
</ul>

源码和DEMO下载:
本文为博主原创,转载请保留出处:
http://chengchenxu.com/Article/22/mvc-fenye
asp.net MVC通用分页组件 使用方便 通用性强的更多相关文章
- 学习ASP.NET MVC(十一)——分页
在这一篇文章中,我们将学习如何在MVC页面中实现分页的方法.分页功能是一个非常实用,常用的功能,当数据量过多的时候,必然要使用分页.在今天这篇文章中,我们学习如果在MVC页面中使用PagedList. ...
- ASP.NET MVC通用权限管理系统(响应布局)源码更新介绍
一.asp.net mvc 通用权限管理系统(响应布局)源码主要以下特点: AngelRM(Asp.net MVC)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash ...
- ReactJS实现的通用分页组件
大家多少都自己写过各种版本的分页工具条吧,像纯服务版的,纯jsWeb板的,Angular版的,因为这个基础得不能再基础的功能太多地方都会用到,下面我给出以个用ReactJS实现的版本,首先上图看下效果 ...
- asp.net mvc 模型验证组件——FluentValidation
asp.net mvc 模型验证组件——FluentValidation 示例 using FluentValidation; public class CustomerValidator: Abst ...
- ASP.NET MVC 简单分页代码
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...
- Asp.net MVC 简单分页 自做简单分页
Asp.net MVC 简单分页: public static string Pager(int page,int pageSize,int total) { ...
- asp.net MVC通用权限管理系统-响应式布局-源码
一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...
- Asp.Net Mvc通用后台管理系统,bootstrap+easyui+权限管理+ORM
产品清单: 1.整站源码,非编译版,方便进行业务的二次开发 2.通用模块与用户等基础数据的数据库脚本 3.bootstrap3.3.1 AceAdmin模板源码 4.easyui1.3.5源码 5.F ...
- ASP.NET MVC 数据分页思想及解决方案代码
作为一个程序猿,数据分页是每个人都会遇到的问题.解决方案更是琳琅满目,花样百出.但基本的思想都是差不多的. 下面给大家分享一个简单的分页器,让初学者了解一下最简单的分页思想,以及在ASP.NET MV ...
随机推荐
- operator的各种问题
a+b = a^b + (a&b)<<1 用位运算实现两数相加 int Add(int a,int b) { return b?Add(a^b,(a&b)<<1 ...
- Ruby 符号【转】
Ruby的符号足以让很多初学者迷惑上一段时间,看过本章节后,或许会解开你心中的疑惑. 在Ruby中,一个符号是就是一个Symbol类的实例,它的语法是在通常的变量名前加一个冒号,如 :my_sy Ru ...
- Welcome-to-Swift-02基本运算符
运算符是检查,改变,合并值的特殊符号或短语.例如,加号+将两个数相加(如let i = 1 + 2).复杂些的运行算例如逻辑与运算符&&(如if enteredDoorCode &am ...
- 【Luogu】P3157动态逆序对(树状数组套主席树)
题目链接 md第一道在NOILinux 下用vim做的紫题.由于我对这个操作系统不是很熟悉,似乎有什么地方搞错了,md调死.(我还打了两遍代码,调了两个小时) 但是这道题并不难,就是树状数组套上主席树 ...
- [HAOI2007] 理想的正方形 (单调队列)
题目链接 Solution MD,经过这道题,算是掌握单调队列了... 可以先预处理出点 \((i,j)\) 往上 \(n\) 的最大值和最小值. 然后再横着做一遍单调队列即可. Code #incl ...
- java面试题之Thread和Runnable是什么关系?
Thread实现了Runnable接口,使得run方法支持多线程: 因类的单一继承原则,推荐多实用Runnable接口
- bzoj 3060[Poi2012]Tour de Byteotia 贪心+生成树
Description 给定一个n个点m条边的无向图,问最少删掉多少条边能使得编号小于等于k的点都不在环上. Analysis 包含关键点的环中 包含从关键点连出的两条边 考虑我们删边删哪些边更优 根 ...
- python作为计算器(数学用法)
1.基本的加减乘除与取余运算 >>> print(5+10) 15 >>> print(5-10) -5 >>> print(5*10) 50 & ...
- luogu 3708 koishi的数学题 递推 线性筛
题目链接 题意 输入一个整数\(n\)\((n\leq 1e6)\),设\(f(x)=\sum_{i=1}^n x\mod i\),你需要输出\(f(1),f(2)...,f(n)\). 输入输出格式 ...
- 开发使用mysql的一些必备知识点整理(二)查询
简介 查询的基本语法 select * from 表名; from关键字后面写表名,表示数据来源于是这张表 select后面写表中的列名,如果是*表示在结果中显示表中所有列 在select后面的列名部 ...