您现在的位置是:网站首页> 编程资料编程资料
ASP.NET MVC4 Razor模板简易分页效果_实用技巧_
2023-05-24
323人已围观
简介 ASP.NET MVC4 Razor模板简易分页效果_实用技巧_
一、无数据提交
第一步,建立一个 Controller命名为PageIndex的空控制器,自定义一个方法如下:
public ActionResult PageIndex(string action, string controller, int currentPage, int pageCount) { //int count = db.Product.Count(); ViewBag.PageCount = pageCount;//从操作中获取总数据页数将传入分页视图页面 ViewBag.CurrentPage = currentPage;//从操作中获取当前页数将传入分页视图页面 ViewBag.action = action; ViewBag.controller = controller; return PartialView(); } 传入四个参数:
action:操作(要分页的视图的操作,默认为Index);
controller:控制器;
currentPage:当前页数;
pageCount:数据总页数
第二步:添加视图(PageIndex)
@if (ViewBag.PageCount == null || ViewBag.PageCount == 0) { 您好,当前没有数据显示! } else { if (ViewBag.CurrentPage <= 10) { 首页| } else { 首页 ... } for (int i = ViewBag.CurrentPage - 3; i < ViewBag.CurrentPage + 3; i++) { if (i <= 0) { continue; } if (i > ViewBag.PageCount) { break; } 第 @i 页| } if (ViewBag.CurrentPage > 1) { 上一页| } if (ViewBag.PageCount > ViewBag.CurrentPage) { 下一页 } if (ViewBag.CurrentPage == ViewBag.PageCount || ViewBag.CurrentPage >= ViewBag.PageCount - 10) { 尾 页 } else { ... 尾 页 } 当前页数: @ViewBag.CurrentPage | 共 @ViewBag.PageCount 页 } 第三步:操作的视图的控制器修改
public ViewResult Index(int? pageIndex) { int pageInd = pageIndex.HasValue ? pageIndex.Value : 1; ViewBag.PageCount = (int)Math.Ceiling(result.Count() / 20.0); //这里的是take,按照每页20个显示 return View(result.OrderBy(t => t.PID).Skip((pageInd - 1) * 20).Take(20)); } 第四步:页面调用(即最后一步)
复制代码 代码如下:
@Html.Action("PageIndex", "Product", new { action = "Index", controller = "Log", pageCount = ViewBag.PageCount, currentPage = ViewBag.CurrentPage })
一般来说,数据都是变动的。
二、有数据提交
第一步:建立一个 Controller命名为PageIndex的空控制器,自定义一个方法如下:
public ActionResult PageIndexKey(int currentPage, int pageCount) { ViewBag.PageCount = pageCount;//从操作中获取总数据页数将传入分页视图页面 ViewBag.CurrentPage = currentPage;//从操作中获取当前页数将传入分页视图页面 return PartialView(); } 第二步:建立分布视图
@Html.Hidden("pageIndex") @if (ViewBag.PageCount == null || ViewBag.PageCount == 0) { 当前没有数据 } else { if (ViewBag.CurrentPage <= 10) { 首页| } else { 首页|...| } for (int i = ViewBag.CurrentPage - 3; i < ViewBag.CurrentPage + 3; i++) { if (i <= 0) { continue; } if (i > ViewBag.PageCount) { break; } 第 @i 页| } if (ViewBag.CurrentPage >1) { 上一页| } if (ViewBag.PageCount > ViewBag.CurrentPage) { 下一页 } if (ViewBag.CurrentPage >= ViewBag.PageCount - 10) { } else { ...|尾 页 } 当前页数: @ViewBag.CurrentPage | 共 @ViewBag.PageCount 页 } 第三步:修改操作视图和控制器
public ViewResult Index(int? pageIndex ,string search) { int pageInd = pageIndex.HasValue ? pageIndex.Value : 1; ViewBag.PageCount = (int)Math.Ceiling(result.Count() / 20.0); return View(result.OrderBy(t => t.PID).Skip((pageInd - 1) * 20).Take(20)); } 视图(页面调用):
@using (Html.BeginForm())
{
根据性别得到查询结果
性别: @Html.TextBox("sex")
@Html.Action("PageIndexKey", "PageIndex", new { pageCount = ViewBag.PageCount, currentPage = ViewBag.CurrentPage })
}
Example:
//数据,一个list的集合 Lists = new List (); s.Add("张军"); ViewBag.PageCount = (int)Math.Ceiling(s.Count() / 20.0); return View(s.Skip((pageInd - 1) * 20).Take(20)); @Html.Action("PageIndex", "PageIndex", new { action = "", controller = "", pageCount = ViewBag.PageCount, currentPage = ViewBag.CurrentPage })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
您可能感兴趣的文章:
- ASP.NET MVC 5使用X.PagedList.Mvc进行分页教程(PagedList.Mvc)
- MVC+jQuery.Ajax异步实现增删改查和分页
- MVC分页之MvcPager使用详解
- ASP.NET MVC分页的实现方法
- ASP.NET MVC分页和排序功能实现
- ASP.NET MVC5 实现分页查询的示例代码
- ASP.NET MVC4 HtmlHelper扩展类,实现分页功能
- Asp.net MVC 中利用jquery datatables 实现数据分页显示功能
- ASP.NET MVC+EF在服务端分页使用jqGrid以及jquery Datatables的注意事项
- MVC使用MvcPager实现分页效果
相关内容
- MVC微信网页授权获取用户OpenId_实用技巧_
- ASP.NET MVC5+EF6+EasyUI后台管理系统 微信公众平台开发之资源环境准备_实用技巧_
- ASP.NET MVC5+EF6+EasyUI后台管理系统 微信公众平台开发之消息管理_实用技巧_
- ASP.NET 程序员都非常有用的85个工具_实用技巧_
- ASP.NET Core 数据保护(Data Protection 集群场景)下篇_实用技巧_
- ASP.NET Core 数据保护(Data Protection)中篇_实用技巧_
- ASP.NET Core 数据保护(Data Protection)上篇_实用技巧_
- ASP.NET Core Kestrel 中使用 HTTPS (SSL)_实用技巧_
- .Net语言Smobiler开发利用Gridview控件设计较复杂的表单_实用技巧_
- .Net语言Smobiler开发之如何仿微信朋友圈的消息样式_实用技巧_
