MVC5 + EF6 + Bootstrap3 (11) 實(shí)現(xiàn)排序、搜索、分頁
前言
本節(jié)我們向這個(gè)頁面中加入排序、搜索和分頁功能。
排序
從上圖中的地址欄中可以看到這個(gè)頁面調(diào)用的是Company Controller下的Index Action.因此我們就先打開Controllers文件夾下的CompanyController.cs文件,寫入如下代碼:
using System.Linq; using System.Web.Mvc; using SlarkInc.DAL; using System; namespace SlarkInc.Controllers { public class CompanyController : Controller { private CompanyContext db = new CompanyContext(); public ViewResult Index(string sortOrder) { ViewBag.FirstNameSortParm = String.IsNullOrEmpty(sortOrder) ? "first_desc" : ""; ViewBag.LastNameSortParm = sortOrder == "last" ? "last_desc" : "last"; var workers = from w in db.Workers select w; switch (sortOrder) { case "first_desc": workers = workers.OrderByDescending(w => w.FirstName); break; case "last_desc": workers = workers.OrderByDescending(w => w.LastName); break; case "last": workers = workers.OrderBy(w => w.LastName); break; default: workers = workers.OrderBy(w => w.FirstName); break; } return View(workers.ToList()); } } }
第11行,Index Action 的參數(shù)sortOrder用來傳遞給Controller排序的信息。sortOrder有4個(gè)可能值。這4個(gè)值體現(xiàn)在17到31行的switch..case語句中。如果是first_desc則對(duì)FirstName用OrderByDescending倒序排列。如果是last_desc則對(duì)LastName倒序排列。如果是last則對(duì)LastName用OrderBy函數(shù)順序排列。如果是空則對(duì)FirstName順序排列。第13-14行用Viewbag存儲(chǔ)當(dāng)前排列的相反排列字符串,用于在View中生成鏈接。第15-16行,用Linq to Entity 從數(shù)據(jù)庫中選取要排序的數(shù)據(jù)。第32行將排序好的數(shù)據(jù)以List的形式傳遞給View。
在對(duì)應(yīng)的View文件~\Views\Company\Index.cshtml中,修改其表頭部分,代碼如下。
<tr> <th> @Html.ActionLink("First Name", "Index", new { sortOrder = ViewBag.FirstNameSortParm }) </th> <th> @Html.ActionLink("Last Name", "Index", new { sortOrder = ViewBag.LastNameSortParm }) </th> <th>@Html.DisplayNameFor(model => model.Sex)</th> <th>@Html.DisplayNameFor(model => model.Rating)</th> </tr>
黃色的部分為修改后的代碼。我們把以前純文本的表頭改成一個(gè)超鏈接,鏈接的參數(shù)從ViewBag中獲得。點(diǎn)擊鏈接可以獲得與當(dāng)前排序相反的排序效果。
通過瀏覽器查看此頁面。之后點(diǎn)擊LastName鏈接,則按照上面代碼會(huì)生成如下頁面:
參數(shù)sortOrder為last則這個(gè)表按lastName順序排列。
搜索
一般查詢頁面都會(huì)有搜索功能幫助我們查看自己想要的頁面。下面我們就來實(shí)現(xiàn)這個(gè)功能。
還是從Controller開始,Index Action的代碼寫成如下形式:
public ViewResult Index(string sortOrder, string searchString) { ViewBag.FirstNameSortParm = String.IsNullOrEmpty(sortOrder) ? "first_desc" : ""; ViewBag.LastNameSortParm = sortOrder == "last" ? "last_desc" : "last"; var workers = from w in db.Workers select w; if (!string.IsNullOrEmpty(searchString)) { workers = workers.Where(w => w.FirstName.Contains(searchString) || w.LastName.Contains(searchString)); } switch (sortOrder) { case "first_desc": workers = workers.OrderByDescending(w => w.FirstName); break; case "last_desc": workers = workers.OrderByDescending(w => w.LastName); break; case "last": workers = workers.OrderBy(w => w.LastName); break; default: workers = workers.OrderBy(w => w.FirstName); break; } return View(workers.ToList()); }
上面代碼中黃色的部分就是我們所添加的。第1行,searchString向Controller傳遞用來搜索的字符串。第7行,字符串不為空時(shí)執(zhí)行搜索。這里的搜索用到了Linq里的Where函數(shù),它通過一個(gè)Lambda表達(dá)式來篩選出符合條件的數(shù)據(jù)。這個(gè)條件就是9-10行的"或"連接的兩個(gè)Contains函數(shù)。Contains函數(shù)表示其所屬字符串是否包含其參數(shù)字符串。整個(gè)篩選條件表示返回所有FisrtName或LastName包含篩選字符串的記錄。
下面看~\Views\Company\Index.cshtml的改動(dòng):
@using(Html.BeginForm()) { <p> Find by name: @Html.TextBox("SearchString","", new { @class = "form-control", @Style = "display:inline" }) @Html.Submit("Submit") </p> }
在table的上面加入這些代碼,它是一個(gè)Form,包含一個(gè)輸入框和提交按鈕,這個(gè)Form會(huì)把輸入框中的搜索字符串提交給當(dāng)前Controller完成搜索操作。其中的輸入框,加入了class和style對(duì)其進(jìn)行了Bootstrap美化。
通過瀏覽器查看這個(gè)頁面,在搜索框中輸入b并且提交,之后會(huì)出現(xiàn)如下頁面:
可以看到搜索結(jié)果是FirstName或LastName包含b(不分大小寫),的所有記錄。
分頁
數(shù)據(jù)查詢免不了要分頁。這里我們用一個(gè)名為PagedList的插件來實(shí)現(xiàn)這個(gè)功能。
如下所示,在菜單欄里選擇工具->庫程序包管理->程序包管理控制臺(tái)。
之后會(huì)在Visual Studio窗口的下面看到一個(gè)程序包管理控制臺(tái)窗口。在其中輸入Install-Package PagedList.Mvc。PagedList就會(huì)自動(dòng)安裝到項(xiàng)目中。窗口如下所示。
Paged List 安裝好后,我們就開始修改代碼,從Controller開始:
using System.Linq; using System.Web.Mvc; using SlarkInc.DAL; using System; using PagedList; namespace SlarkInc.Controllers { public class CompanyController : Controller { private CompanyContext db = new CompanyContext(); public ViewResult Index(string sortOrder, string searchString, string currentFilter, int? page) { ViewBag.CurrentSort = sortOrder; ViewBag.FirstNameSortParm = String.IsNullOrEmpty(sortOrder) ? "first_desc" : ""; ViewBag.LastNameSortParm = sortOrder == "last" ? "last_desc" : "last"; if(searchString != null) { page = 1; } else { searchString = currentFilter; } ViewBag.CurrentFilter = searchString; var workers = from w in db.Workers select w; if (!string.IsNullOrEmpty(searchString)) { workers = workers.Where(w => w.FirstName.Contains(searchString) || w.LastName.Contains(searchString)); } switch (sortOrder) { case "first_desc": workers = workers.OrderByDescending(w => w.FirstName); break; case "last_desc": workers = workers.OrderByDescending(w => w.LastName); break; case "last": workers = workers.OrderBy(w => w.LastName); break; default: workers = workers.OrderBy(w => w.FirstName); break; } int pageSize = 3; int pageNumber = (page ?? 1); return View(workers.ToPagedList(pageNumber,pageSize)); } } }
黃色標(biāo)記的為需要改動(dòng)的部分。第5行,需要引用PagedList。第12行currentFilter參數(shù)用來在翻頁時(shí)保持搜索字符串不丟失。第17到25行的作用是,當(dāng)有一個(gè)新的字符串要搜索,那么翻當(dāng)前頁就自動(dòng)變成第一頁,否則,當(dāng)前頁不變。第49-51行設(shè)置每頁3條數(shù)據(jù),設(shè)置頁數(shù),并將數(shù)據(jù)以List的形式發(fā)送個(gè)View。其中(page ?? 1)的意思是如果page為null則給page賦值為1否則,page不為null那么該是多少就是多少。所以能讓默認(rèn)頁為1.
@model PagedList.IPagedList<SlarkInc.Models.Worker> @using PagedList.Mvc; <link href="~/Content/PagedList.css" rel="stylesheet" /> <br /> @using(Html.BeginForm("Index","Company",FormMethod.Get)) { <p> Find by name: @Html.TextBox("SearchString",ViewBag.CurrentFilter as string, new { @class = "form-control", @Style = "display:inline" }) @Html.Submit("Submit") </p> } <table class="table"> <tr> <th> @Html.ActionLink("First Name", "Index", new { sortOrder = ViewBag.FirstNameSortParm }) </th> <th> @Html.ActionLink("Last Name", "Index", new { sortOrder = ViewBag.LastNameSortParm }) </th> <th>Sex</th> <th>Rating</th> </tr> @foreach (var item in Model) { <tr> <td> @Html.DisplayFor(modelItem => item.FirstName) </td> <td> @Html.DisplayFor(modelItem => item.LastName) </td> <td> @Html.DisplayFor(modelItem => item.Sex) </td> <td> @Html.DisplayFor(modelItem => item.Rating) </td> </tr> } </table> <br/> Page @(Model.PageCount < Model.PageNumber ? 0 : Model.PageNumber) of @Model.PageCount @Html.PagedListPager(Model, page => Url.Action("Index", new {page, sortOrder = ViewBag.CurrentSort, currentFilter = ViewBag.CurrentFilter}))
第1行定義了PagedList 類型的model。第2行引用PagedList。第3行,引入,PagedList相關(guān)的css文件,這個(gè)文件在安裝插件的時(shí)候會(huì)自動(dòng)保存到項(xiàng)目里。第5行BeginForm函數(shù)的參數(shù)有變化,其生成的Form會(huì)使用Get方法。Get方法會(huì)在url里顯示提交的參數(shù),這樣可以通過url來記錄查詢參數(shù),方便通過復(fù)制url給他人來展現(xiàn)自己的查詢結(jié)果。第42行用于顯示第幾頁,共幾頁。第43-44行,用于生成每一頁的按鈕。
運(yùn)行此頁面,當(dāng)頁面出來時(shí)點(diǎn)擊頁面下方的"2"按鈕轉(zhuǎn)到第2頁。生成的頁面如下所示:
可以看到頁面下方的分頁按鈕和頁數(shù)統(tǒng)計(jì),美觀大方。
結(jié)尾
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Visual Studio 2017下ASP.NET CORE的TagHelper智能提示解決辦法
這篇文章主要為大家詳細(xì)介紹了Visual Studio 2017下ASP.NET CORE TagHelper智能提示的解決辦法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03ASP.NET 修復(fù) IIS 映射具體實(shí)現(xiàn)步驟
本文主要介紹IIS映射的具體步驟,希望對(duì)大家有所幫助。2016-05-05Asp.net Core項(xiàng)目配置HTTPS支持
這篇文章介紹了Asp.net Core項(xiàng)目配置HTTPS支持的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09ASP.NET中將聲音文件添加到資源中并進(jìn)行播放的方法
這篇文章主要介紹了ASP.NET中將聲音文件添加到資源中并進(jìn)行播放的方法,實(shí)例分析了聲音文件的添加及播放實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07Springboot服務(wù)Docker化自動(dòng)部署的實(shí)現(xiàn)方法
這篇文章主要介紹了Springboot服務(wù)Docker化自動(dòng)部署的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03一個(gè)完整的ASP.NET 2.0 URL重寫方案[翻譯]
這篇文章描述了一個(gè)完整的 ASP.NET 2.0 URL 重寫方案。這個(gè)方案使用正則表達(dá)式來定義重寫規(guī)則并解決通過虛擬 URLs 訪問頁面產(chǎn)生回發(fā)事件的一些可能的困難。2009-11-11