系列教程:MVC5 + EF6 + Bootstrap3 上一節:MVC5 + EF6 + Bootstrap3 (10) 數據查詢頁面 源碼下載:點我下載 我工作的源碼:http://www.jinhusns.com/Products/Download/?type=xcj 目錄 前言 排序 搜索 ...
系列教程:MVC5 + EF6 + Bootstrap3
上一節:MVC5 + EF6 + Bootstrap3 (10) 數據查詢頁面
源碼下載:點我下載
我工作的源碼:http://www.jinhusns.com/Products/Download/?type=xcj
目錄
前言
上一節我們做到瞭如下的一個基礎查詢頁面。本節我們向這個頁面中加入排序、搜索和分頁功能。
排序
從上圖中的地址欄中可以看到這個頁面調用的是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 的參數sortOrder用來傳遞給Controller排序的信息。sortOrder有4個可能值。這4個值體現在18到32行的 switch..case語句中。如果是first_desc則對FirstName用OrderByDescending倒序排列。如果是 last_desc則對LastName倒序排列。如果是last則對LastName用OrderBy函數順序排列。如果是空則對FirstName順 序排列。第13-14行用Viewbag存儲當前排列的相反排列字元串,用於在View中生成鏈接。第15-16行,用Linq to Entity 從資料庫中選取要排序的數據。第33行將排序好的數據以List的形式傳遞給View。
在對應的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>
黃色的部分為修改後的代碼。我們把以前純文本的表頭改成一個超鏈接,鏈接的參數從ViewBag中獲得。點擊鏈接可以獲得與當前排序相反的排序效果。
通過瀏覽器查看此頁面。之後點擊LastName鏈接,則按照上面代碼會生成如下頁面:
參數sortOrder為last則這個表按lastName順序排列。
搜索
一般查詢頁面都會有搜索功能幫助我們查看自己想要的頁面。下麵我們就來實現這個功能。
還是從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行,字元串不為空時執行搜索。 這裡的搜索用到了Linq里的Where函數,它通過一個Lambda表達式來篩選出符合條件的數據。這個條件就是9-10行的"或"連接的兩個 Contains函數。Contains函數表示其所屬字元串是否包含其參數字元串。整個篩選條件表示返回所有FisrtName或LastName包含 篩選字元串的記錄。
下麵看~\Views\Company\Index.cshtml的改動:
@using(Html.BeginForm())
{
<p>
Find by name: @Html.TextBox("SearchString","", new { @class = "form-control", @Style = "display:inline" })
@Html.Submit("Submit")
</p>
}
在table的上面加入這些代碼,它是一個Form,包含一個輸入框和提交按鈕,這個Form會把輸入框中的搜索字元串提交給當前Controller完成搜索操作。其中的輸入框,加入了class和style對其進行了Bootstrap美化。
通過瀏覽器查看這個頁面,在搜索框中輸入b並且提交,之後會出現如下頁面:
可以看到搜索結果是FirstName或LastName包含b(不分大小寫),的所有記錄。
分頁
數據查詢免不了要分頁。這裡我們用一個名為PagedList的插件來實現這個功能。
如下所示,在菜單欄里選擇工具->庫程式包管理->程式包管理控制台。
之後會在Visual Studio視窗的下麵看到一個程式包管理控制台視窗。在其中輸入Install-Package PagedList.Mvc。PagedList就會自動安裝到項目中。視窗如下所示。
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));
}
}
}
黃 色標記的為需要改動的部分。第5行,需要引用PagedList。第12行currentFilter參數用來在翻頁時保持搜索字元串不丟失。第17到 25行的作用是,當有一個新的字元串要搜索,那麼翻當前頁就自動變成第一頁,否則,當前頁不變。第49-51行設置每頁3條數據,設置頁數,並將數據以 List的形式發送個View。其中(page ?? 1)的意思是如果page為null則給page賦值為1否則,page不為null那麼該是多少就是多少。所以能讓預設頁為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相關的css文件,這個文件在安裝插件的時候會自動保存到項目里。第 5行BeginForm函數的參數有變化,其生成的Form會使用Get方法。Get方法會在url里顯示提交的參數,這樣可以通過url來記錄查詢參 數,方便通過複製url給他人來展現自己的查詢結果。第42行用於顯示第幾頁,共幾頁。第43-44行,用於生成每一頁的按鈕。
運行此頁面,當頁面出來時點擊頁面下方的"2"按鈕轉到第2頁。生成的頁面如下所示:
可以看到頁面下方的分頁按鈕和頁數統計,美觀大方。
結尾
嗯,不知不覺,快半夜一點了。加油!
喜歡的話就推薦下吧http://www.jinhusns.com/Products/Download/?type=xcj