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 ...
随机推荐
- [转]如何把嵌套的python list转成一个一维的python list?
import itertools a = [[1,2,3],[4,5,6], [7], [8,9]] out = list(itertools.chain.from_iterable(a))
- 下载,配置环境变量,第一个demo
一.在 http://www.oracle.com 下载java JDK 安装到自定义的地方. 二.配置环境变量:在我的电脑→高级系统设置→环境变量 ① 找到Path新增一个路径(该路径为JDK存放的 ...
- 代码托管在阿里云并用git拉取
1.在阿里云上注册一个账号,https://code.aliyun.com/ 2.创建组 3.添加组员权限 4.添加项目 5.复制项目地址 安装git https://git-scm.com/ ...
- Struts has detected an unhandled exception异常
近期在写struts框架的时候会时不时的出现这个异常,多次实验以后发现,目前解决的方法只能通过重新部署项目再重新启动服务器解决,通常这个异常会出现在DMI即动态方法调用过程中.
- iOS学习笔记49-Swift(九)访问控制
一.Swift的访问控制 Swift中的访问控制模型基于模块和源文件这两个概念 模块指的是Framework或App bundle.在Swift中,可以用import关键字引入自己的工程. 源文件指的 ...
- kb-07专题线段树-04--离散化;
/* poj2528 线段树 好题,用到了离散化,二分定位,特殊的区间查寻方式:在下面的代码注释中有详细的解释: */ #include<iostream> #include<cst ...
- BZOJ1879 [Sdoi2009]Bill的挑战 【状压dp】
题目 输入格式 本题包含多组数据. 第一行:一个整数T,表示数据的个数. 对于每组数据: 第一行:两个整数,N和K(含义如题目表述). 接下来N行:每行一个字符串. T ≤ 5,M ≤ 15,字符串长 ...
- restful的nginx配置方法
location /{ root /webserver/www/a.tk.com; index index.html index.htm index.php; if ( $document_uri ~ ...
- 【前端学习笔记】2015-09-01 附二 关于jq选择器的简单运用
根据id来选择------$("#id") 根据class来选择------$(".classname") 根据tag来选择-------$("tag ...
- LA 6450 social advertising(dfs剪枝)
6450 Social AdvertisingYou have decided to start up a new social networking company. Other existing ...