English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
一、无数据提交
第一步,建立一个 Controller命名为PageIndex的空控制器,自定义一个方法如下:
public ActionResult PageIndex(string action, string controller, int currentPage, int pageCount) { //int count = db.Product.Count(); ViewBag.PageCount = pageCount;//Ottieni il numero totale di pagine dei dati dall'azione e passalo alla pagina di visualizzazione della paginazione ViewBag.CurrentPage = currentPage;//Ottieni il numero della pagina corrente dall'azione e passalo alla pagina di visualizzazione della paginazione ViewBag.action = action; ViewBag.controller = controller; return PartialView(); }
传入四个参数:
action:操作(要分页的视图的操作,默认为Index);
controller:控制器;
currentPage:当前页数;
pageCount:数据总页数
Secondo passo:添加视图(PageIndex)
@if (ViewBag.PageCount == null || ViewBag.PageCount == 0) { <span>您好,当前没有数据显示!</span> } else { se (ViewBag.CurrentPage <= 10) { |</span> 首页 } else { <a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = 1 }, null)"> 首页 <span><a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.CurrentPage - 10 }, null)"> ...</a> </span> } per (int i = ViewBag.CurrentPage - 3; i < ViewBag.CurrentPage + 3; i++) { se (i <= 0) { continua; } if (i > ViewBag.PageCount) { break; } <span><a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = i }, null)"> Pagina @i</a>|</span> } if (ViewBag.CurrentPage > 1) { <span><a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.CurrentPage - 1 }, null)"> Pagina precedente</a>|</span> } if (ViewBag.PageCount > ViewBag.CurrentPage) { <span><a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.CurrentPage + 1 }, null)"> Pagina successiva</a></span> } if (ViewBag.CurrentPage == ViewBag.PageCount || ViewBag.CurrentPage >= ViewBag.PageCount - 10) { <a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.PageCount }, null)"> Pagina finale</a> } else { <span><a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.CurrentPage + 10 }, null)"> ...</a></span> <a href="@Url.Action(ViewBag.action, ViewBag.controller, new { PageIndex = ViewBag.PageCount }, null)"> Pagina finale</a> } <span style="padding-left: 20px">Pagina corrente: @ViewBag.CurrentPage | Di @ViewBag.PageCount pagine totali</span> </span> }
Passo terzo:Modifica del controller della vista dell'operazione
public ViewResult Index(int? pageIndex) { int pageInd = pageIndex.HasValue ? pageIndex.Value : 1; ViewBag.PageCount = (int)Math.Ceiling(result.Count() / 20.0); //Questo è take, mostra 20 per pagina return View(result.OrderBy(t => t.PID).Skip((pageInd - 1) * 20).Take(20)); }
Passo 4:Chiamata di pagina (cioè l'ultimo passo)
@Html.Action("PageIndex", "Product", new { action = "Index", controller = "Log", pageCount = ViewBag.PageCount, currentPage = ViewBag.CurrentPage })
Di solito, i dati sono variabili.
Secondo: ci sono dati inviati
Primo passo: Crea un controller vuoto chiamato PageIndex, e definisci un metodo come segue:
public ActionResult PageIndexKey(int currentPage, int pageCount) { ViewBag.PageCount = pageCount;//Ottieni il numero totale di pagine dei dati dall'azione e passalo alla pagina di visualizzazione della paginazione ViewBag.CurrentPage = currentPage;//Ottieni il numero della pagina corrente dall'azione e passalo alla pagina di visualizzazione della paginazione return PartialView(); }
Secondo passo:Crea una vista distribuita
<script> $(function () { $("#pageingByForm a").click(function (event) { $("#pageIndex").val($(this).attr("pageIndex")); //$(this).parent("Form").submit(); document.getElementsByTagName("Form").item(0).submit(); event.preventDefault(); }); }); </script> @Html.Hidden("pageIndex") <div id="pageingByForm"> @if (ViewBag.PageCount == null || ViewBag.PageCount == 0) { <span>Non ci sono dati</span> } else { se (ViewBag.CurrentPage <= 10) { <span><a pageindex="1" href="#">Pagina iniziale</a>|</span> } else { <span><a pageindex="1" href="#">Pagina iniziale</a>|</span> <span><a pageIndex="@(ViewBag.CurrentPage - 10)" href="#">...</a>|</span> } per (int i = ViewBag.CurrentPage - 3; i < ViewBag.CurrentPage + 3; i++) { se (i <= 0) { continua; } if (i > ViewBag.PageCount) { break; } <span><a pageIndex="@i" href="#">Pagina @i</a>|</span> } if (ViewBag.CurrentPage > 1) { <span><a pageIndex="@(ViewBag.CurrentPage - 1)" href="#">Pagina precedente</a>|</span> } if (ViewBag.PageCount > ViewBag.CurrentPage) { <span><a pageIndex="@(ViewBag.CurrentPage + 1)" href="#">Pagina successiva</a></span> } if (ViewBag.CurrentPage >= ViewBag.PageCount - 10) { } else { <span><a pageIndex="@(ViewBag.CurrentPage + 10)" href="#">...</a>|</span> <span><a pageIndex="@ViewBag.PageCount" href="#">Pagina finale</a></span> } <span style="padding-left: 20px">Pagina corrente: @ViewBag.CurrentPage | Di @ViewBag.PageCount pagine totali</span> </span> } </div>
Passo terzo:Modifica vista e controller operazione
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)); }
Vista (richiesta di pagina):
@using (Html.BeginForm())
{
Ottenere i risultati della ricerca in base al sesso
Sesso: @Html.TextBox("sex")
<input type="submit" value="Ricerca" />
@Html.Action("PageIndexKey", "PageIndex", new { pageCount = ViewBag.PageCount, currentPage = ViewBag.CurrentPage })
}
Esempio:
// una raccolta di dati, una raccolta di list List<string> s = new List<string>(); 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 })
Questo è tutto il contenuto dell'articolo, speriamo che sia utile per la tua apprendimento, e ti preghiamo di sostenere e applaudire il tutorial.
Dichiarazione: il contenuto di questo articolo è stato tratto da Internet, il copyright spetta ai rispettivi autori, il contenuto è stato contribuito e caricato autonomamente dagli utenti di Internet, questo sito non detiene i diritti di proprietà, non è stato editato manualmente e non assume responsabilità legali correlate. Se trovi contenuti sospetti di violazione del copyright, ti preghiamo di inviare una e-mail a: notice#oldtoolbag.com (al momento dell'invio dell'e-mail, sostituisci # con @) per segnalare, fornendo prove pertinenti. Una volta verificata, questo sito eliminerà immediatamente i contenuti sospetti di violazione del copyright.