日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線(xiàn)溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能-創(chuàng)新互聯(lián)

這篇文章主要介紹了MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)建站是一家專(zhuān)業(yè)提供遼陽(yáng)縣企業(yè)網(wǎng)站建設(shè),專(zhuān)注與網(wǎng)站建設(shè)、成都網(wǎng)站制作、H5建站、小程序制作等業(yè)務(wù)。10年已為遼陽(yáng)縣眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專(zhuān)業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。

前言


本節(jié)我們向這個(gè)頁(yè)面中加入排序、搜索和分頁(yè)功能。


MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

排序

從上圖中的地址欄中可以看到這個(gè)頁(yè)面調(diào)用的是Company Controller下的Index Action.因此我們就先打開(kāi)Controllers文件夾下的CompanyController.cs文件,寫(xiě)入如下代碼:


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用來(lái)傳遞給Controller排序的信息。sortOrder有4個(gè)可能值。這4個(gè)值體現(xiàn)在17到31行的switch..case語(yǔ)句中。如果是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ù)庫(kù)中選取要排序的數(shù)據(jù)。第32行將排序好的數(shù)據(jù)以L(fǎng)ist的形式傳遞給View。

在對(duì)應(yīng)的View文件~\Views\Company\Index.cshtml中,修改其表頭部分,代碼如下。



    
      @Html.ActionLink("First Name", "Index", new { sortOrder = ViewBag.FirstNameSortParm })
    
    
      @Html.ActionLink("Last Name", "Index", new { sortOrder = ViewBag.LastNameSortParm })
    
    @Html.DisplayNameFor(model => model.Sex)
    @Html.DisplayNameFor(model => model.Rating)

黃色的部分為修改后的代碼。我們把以前純文本的表頭改成一個(gè)超鏈接,鏈接的參數(shù)從ViewBag中獲得。點(diǎn)擊鏈接可以獲得與當(dāng)前排序相反的排序效果。

 通過(guò)瀏覽器查看此頁(yè)面。之后點(diǎn)擊LastName鏈接,則按照上面代碼會(huì)生成如下頁(yè)面:

 MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

參數(shù)sortOrder為last則這個(gè)表按lastName順序排列。

搜索

一般查詢(xún)頁(yè)面都會(huì)有搜索功能幫助我們查看自己想要的頁(yè)面。下面我們就來(lái)實(shí)現(xiàn)這個(gè)功能。

還是從Controller開(kāi)始,Index Action的代碼寫(xiě)成如下形式:


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傳遞用來(lái)搜索的字符串。第7行,字符串不為空時(shí)執(zhí)行搜索。這里的搜索用到了Linq里的Where函數(shù),它通過(guò)一個(gè)Lambda表達(dá)式來(lái)篩選出符合條件的數(shù)據(jù)。這個(gè)條件就是9-10行的"或"連接的兩個(gè)Contains函數(shù)。Contains函數(shù)表示其所屬字符串是否包含其參數(shù)字符串。整個(gè)篩選條件表示返回所有FisrtName或LastName包含篩選字符串的記錄。

 下面看~\Views\Company\Index.cshtml的改動(dòng):


@using(Html.BeginForm())
{
   

      Find by name: @Html.TextBox("SearchString","", new { @class = "form-control", @Style = "display:inline" })       @Html.Submit("Submit")    

}

在table的上面加入這些代碼,它是一個(gè)Form,包含一個(gè)輸入框和提交按鈕,這個(gè)Form會(huì)把輸入框中的搜索字符串提交給當(dāng)前Controller完成搜索操作。其中的輸入框,加入了class和style對(duì)其進(jìn)行了Bootstrap美化。

通過(guò)瀏覽器查看這個(gè)頁(yè)面,在搜索框中輸入b并且提交,之后會(huì)出現(xiàn)如下頁(yè)面:

MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

可以看到搜索結(jié)果是FirstName或LastName包含b(不分大小寫(xiě)),的所有記錄。

分頁(yè)

數(shù)據(jù)查詢(xún)免不了要分頁(yè)。這里我們用一個(gè)名為PagedList的插件來(lái)實(shí)現(xiàn)這個(gè)功能。

如下所示,在菜單欄里選擇工具->庫(kù)程序包管理->程序包管理控制臺(tái)。


MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

之后會(huì)在Visual Studio窗口的下面看到一個(gè)程序包管理控制臺(tái)窗口。在其中輸入Install-Package PagedList.Mvc。PagedList就會(huì)自動(dòng)安裝到項(xiàng)目中。窗口如下所示。


MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

Paged List 安裝好后,我們就開(kāi)始修改代碼,從Controller開(kāi)始:


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ù)用來(lái)在翻頁(yè)時(shí)保持搜索字符串不丟失。第17到25行的作用是,當(dāng)有一個(gè)新的字符串要搜索,那么翻當(dāng)前頁(yè)就自動(dòng)變成第一頁(yè),否則,當(dāng)前頁(yè)不變。第49-51行設(shè)置每頁(yè)3條數(shù)據(jù),設(shè)置頁(yè)數(shù),并將數(shù)據(jù)以L(fǎng)ist的形式發(fā)送個(gè)View。其中(page ?? 1)的意思是如果page為null則給page賦值為1否則,page不為null那么該是多少就是多少。所以能讓默認(rèn)頁(yè)為1.


 @model PagedList.IPagedList
@using PagedList.Mvc;

      
      @using(Html.BeginForm("Index","Company",FormMethod.Get))
      {
        

          Find by name: @Html.TextBox("SearchString",ViewBag.CurrentFilter as string, new { @class = "form-control", @Style = "display:inline" })           @Html.Submit("Submit")         

      }               @Html.ActionLink("First Name", "Index", new { sortOrder = ViewBag.FirstNameSortParm })                 @Html.ActionLink("Last Name", "Index", new { sortOrder = ViewBag.LastNameSortParm })          Sex     Rating      @foreach (var item in Model)   {                     @Html.DisplayFor(modelItem => item.FirstName)                       @Html.DisplayFor(modelItem => item.LastName)                       @Html.DisplayFor(modelItem => item.Sex)                       @Html.DisplayFor(modelItem => item.Rating)               }
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 類(lèi)型的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ù),這樣可以通過(guò)url來(lái)記錄查詢(xún)參數(shù),方便通過(guò)復(fù)制url給他人來(lái)展現(xiàn)自己的查詢(xún)結(jié)果。第42行用于顯示第幾頁(yè),共幾頁(yè)。第43-44行,用于生成每一頁(yè)的按鈕。

運(yùn)行此頁(yè)面,當(dāng)頁(yè)面出來(lái)時(shí)點(diǎn)擊頁(yè)面下方的"2"按鈕轉(zhuǎn)到第2頁(yè)。生成的頁(yè)面如下所示:

MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能

可以看到頁(yè)面下方的分頁(yè)按鈕和頁(yè)數(shù)統(tǒng)計(jì),美觀(guān)大方。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!


文章標(biāo)題:MVC5+EF6+Bootstrap3怎么實(shí)現(xiàn)排序、搜索、分頁(yè)功能-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)網(wǎng)址:http://www.dlmjj.cn/article/ccgedj.html