真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ASP.NETMVC中怎么實現(xiàn)分頁和排序功能-創(chuàng)新互聯(lián)

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了大余免費建站歡迎大家使用!

1.首先新建一個空白的MVC項目,在Model文件夾里,新建一個Student實體


ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

Student實體中的代碼:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace PagingAndSortingInMVC.Models
{
 public class Student
 {
 public int ID { get; set; }

 public string Name { get; set; }

 public string Sex { get; set; }

 public string Email { get; set; }

 public int Age { get; set; } 
 }
}

2.添加EF引用之后,我們在根目錄下,在創(chuàng)建一個文件夾Map,在里面創(chuàng)建一個類StudentMap

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

StudentMap類的代碼:

using PagingAndSortingInMVC.Models;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity.ModelConfiguration;
using System.Linq;
using System.Web;

namespace PagingAndSortingInMVC.Map
{
 public class StudentMap:EntityTypeConfiguration
 {
 public StudentMap()
 {
  //配置主鍵
  this.HasKey(s => s.ID);

  //把ID列設(shè)置為自增列
  this.Property(s => s.ID).HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
  //配置列
  this.Property(s => s.Name).HasMaxLength(50).IsRequired();
  this.Property(s => s.Sex).HasMaxLength(2).IsRequired();
  this.Property(s => s.Age).IsRequired();
  this.Property(s => s.Email).HasMaxLength(100).IsRequired();
 }
 }
}

3.在根目錄下,再新建一個文件夾DBHelper,在里面新建一個類StudentDBContext

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

StudentDBContext類的代碼:

using PagingAndSortingInMVC.Map;
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web;

namespace PagingAndSortingInMVC.DBHelper
{
 public class StudentDBContext:DbContext
 {
 public StudentDBContext()
  : base("name=DbConnectionString") 
 {
 
 }

 protected override void OnModelCreating(DbModelBuilder modelBuilder)
 {
  //因為這里只有一個實體,就不搞的那么復(fù)雜了,不用反射來做。直接添加單個實體的配置
  modelBuilder.Configurations.Add(new StudentMap());
  base.OnModelCreating(modelBuilder);
 }
 }
}

然后在配置文件中加上:




具體的位置在這:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

4.好了,現(xiàn)在實體和數(shù)據(jù)庫的配置都寫好了,現(xiàn)在我們使用數(shù)據(jù)庫遷移技術(shù)【Migrations】來自動生成數(shù)據(jù)庫,首先打開程序包管理控制臺。
添加一行語句:Enable-Migrations,然后按回車鍵:


ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

這個時候,就在我們程序中生成了一個文件夾Migrations,里面有一個類Configuration:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

修改Configuration類中的代碼:把 AutomaticMigrationsEnabled 設(shè)置為true;并添加一句代碼,讓遷移過程中,沒有數(shù)據(jù)丟失:  
AutomaticMigrationDataLossAllowed = false;


ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

然后在程序包管理控制臺中接著輸入:
 Update-Database  -Verbose


注意:【-Verbose和Database之間有空格】,之所以輸入-Verbose就是可以在控制臺看到生成的SQL語句:

PM> Update-Database -Verbose
Using StartUp project 'PagingAndSortingInMVC'.
Using NuGet project 'PagingAndSortingInMVC'.
Specify the '-Verbose' flag to view the SQL statements being applied to the target database.
Target database is: 'MyStudentDB' (DataSource: ., Provider: System.Data.SqlClient, Origin: Configuration).
No pending explicit migrations.
Applying automatic migration: 201607180249098_AutomaticMigration.
CREATE TABLE [dbo].[Students] (
 [ID] [int] NOT NULL IDENTITY,
 [Name] [nvarchar](50) NOT NULL,
 [Sex] [nvarchar](2) NOT NULL,
 [Email] [nvarchar](100) NOT NULL,
 [Age] [int] NOT NULL,
 CONSTRAINT [PK_dbo.Students] PRIMARY KEY ([ID])
)
CREATE TABLE [dbo].[__MigrationHistory] (
 [MigrationId] [nvarchar](150) NOT NULL,
 [ContextKey] [nvarchar](300) NOT NULL,
 [Model] [varbinary](max) NOT NULL,
 [ProductVersion] [nvarchar](32) NOT NULL,
 CONSTRAINT [PK_dbo.__MigrationHistory] PRIMARY KEY ([MigrationId], [ContextKey])
)
INSERT [dbo].[__MigrationHistory]([MigrationId], [ContextKey], [Model], [ProductVersion])
VALUES (N'201607180249098_AutomaticMigration', N'PagingAndSortingInMVC.Migrations.Configuration', 0x1F8B0800000000000400CD57DB6EDB38107D5FA0FF20F03935ED040B7403B9856327BBC6D64950A579A7A5B1422C456A492AB0BFAD0FFB49FB0B3BD4DD926F31DA451120B0A8993333673817FDFBED1FFFD33A11DE2B68C3951C93D160483C90A18AB88CC724B3ABF71FC8A78FEF7EF16FA364ED3D5772574E0E35A51993176BD36B4A4DF80209338384875A19B5B283502594458A5E0E87BFD1D188024210C4F23CFF4B262D4F207FC0C7A99221A4366362A12210A63CC737418EEADDB3044CCA4218934716A36F1319054A5BFC35978BE7E96076F307881434F1268233F42A00B1221E93525966D1E7EBAF0602AB958C83140F9878DAA480722B260C94B15C37E2A78635BC7461D146B1820A336355F246C0D155C913EDAA9FC536A97944266F9171BB7151E76C2243368B405AE2756D5D4F857672FBB82E723428F52FBC9D5217F565C13BE5FE2EBC69266CA6612C21B39A0954CC9682877FC2E649FD05722C3321DA2EA3D3F86EEB008F1EB5C23CDBCD17589581CC67C4A3DB7AB4AB58ABB5748A18E7D25E5D12EF1E8DB3A580FA46B4F808ACD2F03B48D0CC42F4C8AC058D099DBBF091D39EF58E2DF7BFB28657101922DE82AD3F838CEDCB98FC8AA574C7D7105507A5035F25C73A441DAB33D8E1E061A301AC0FD8BCFC11266F13C6C501A3A3E10F897412C3B15CB6017CDA5442BF3EB01359C631D3DB4532BB712F60BDAB5AB0B1940563CA08B6DD2D8003B0DB9086788D2345BF1AD425B9CBE1DAB5A63BD2A23D566D94EEE9A3FE82A52966A3D557CB132F289AEAF47DF0F60E93141834343B1A4DED6D6D098B88C5D0798BA6D1D33BAE8D9D31CB96CCA56B1A253DB15E22F6905C99EB70DDED220DF59582FB5D281D9E3075923A900DA9771867821279C8507BD674DC9E663EE898607A47979A2A9125725FA73BA45DF49DB67E71723A42DE44DA00F9C1E9FA654768239447A763E4E5DD46C80FFAFA3EEDD0DF4D39EDE5BC3333BA77E8500D76456AEB752D766ACE2FEFFFF105A757108508F19098571EE5C5B0311692811318047F8BA9E079D7A804164CF215185B8C5582F5FAA1B317FD3C3B0A352612A72D2AFFFB6AC01DA94787FF1BC7557B1B90AF4C872F4CF7F681F387FD4EC86333F1C82CDF89994FF3F34775CEED771CD4FD3172D2143E34848BBA1B9368A9D0EBC2CF66789F39A2FB6DC0A7EDAF217F0686C70D84FB369210BAFA6A402B99B95CA98A620CADED5125D2C9C0022C8B90A1094EB6150B2DBE0EC1987C557B6622CB53BF84682E1F329B6676620C244BB1B5E3FAF4B0FD7C0FD9F6D97F48DD93F91E21A09B1C43800779937111D57EDFEDB8427B20DC65294B1ABDC25515E1E24D8D74AFE48940257D334841BA7BF104492A10CC3CC880BDC239BEE13AF91962166EAA6EBE1FE47822B669F7679CC59A25A6C468F4DD173E759FF81FFF0366E046F514100000 , N'6.1.3-40302')

Running Seed method.
PM>

打開數(shù)據(jù)庫,我們看到,就生成我們想要的數(shù)據(jù)庫和表了:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

既然要分頁,就開始引入分頁控件吧,引入PagedList.MVC

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

5.新建一個空白模板的Student控制器。


ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

控制器里面就是我們主要的邏輯代碼了:


using PagingAndSortingInMVC.DBHelper;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using PagedList;
using PagingAndSortingInMVC.Models;

namespace PagingAndSortingInMVC.Controllers
{
 public class StudentController : Controller
 {
 private StudentDBContext db=null;
 public StudentController()
 {
  db = new StudentDBContext();
 }
 
 /// 
 /// 首頁【查詢分頁數(shù)據(jù)】
 /// 
 /// 根據(jù)什么排序
 /// 當前排序字段
 /// 當前頁
 /// 
 public ActionResult Index(string sortBy,string currentSort,int? page)
 {
  int pageIndex = 1;
  int pageSize = 5;
  //判斷page是否有值,有的話就給值,沒有就賦值1
  pageIndex = page.HasValue ? Convert.ToInt32(page) : 1;
  ViewBag.CurrentSort = sortBy; 
//這句必須要,否則剛開始是空的,報錯,就不能循環(huán)了。
sortBy = string.IsNullOrEmpty(sortBy) ? "Name" : sortBy; //如果sortBy為空,就設(shè)置為Name,下面設(shè)置的時候,默認按照名稱排序
 
  IPagedList lstStudent = null;
  switch (sortBy)
  {
  case "Name":
   //如果sortBy==currentSort,就按照對應(yīng)字段降序排列,并分頁。否則升序。
   if (sortBy.Equals(currentSort))
   {
   lstStudent = db.Set().
    OrderByDescending(s => s.Name).
    ToPagedList(pageIndex, pageSize);    //根據(jù)一熱心博友的建議,加上了這句,點擊相應(yīng)的列,升序降序循環(huán)?!               ?nbsp;ViewBag.CurrentSort = null;
   }
   else
   {
   lstStudent = db.Set().
    OrderBy(s => s.Name).
    ToPagedList(pageIndex, pageSize);
   }
   break;

  case "Sex":
   //如果sortBy==currentSort,就按照對應(yīng)字段降序排列,并分頁。否則升序。
   if (sortBy.Equals(currentSort))
   {
   lstStudent = db.Set().
    OrderByDescending(s => s.Sex).
    ToPagedList(pageIndex, pageSize); //根據(jù)一熱心博友的建議,加上了這句,點擊相應(yīng)的列,升序降序循環(huán)。                 ViewBag.CurrentSort = null; 
   }
   else
   {
   lstStudent = db.Set().
    OrderBy(s => s.Sex).
    ToPagedList(pageIndex, pageSize);
   }
   break;

  case "Email":
   //如果sortBy==currentSort,就按照對應(yīng)字段降序排列,并分頁。否則升序。
   if (sortBy.Equals(currentSort))
   {
   lstStudent = db.Set().
    OrderByDescending(s => s.Email).
    ToPagedList(pageIndex, pageSize); //根據(jù)一熱心博友的建議,加上了這句,點擊相應(yīng)的列,升序降序循環(huán)。                 ViewBag.CurrentSort = null; 
   }
   else
   {
   lstStudent = db.Set().
    OrderBy(s => s.Email).
    ToPagedList(pageIndex, pageSize);
   }
   break;

  case "Age":
   //如果sortBy==currentSort,就按照對應(yīng)字段降序排列,并分頁。否則升序。
   if (sortBy.Equals(currentSort))
   {
   lstStudent = db.Set().
    OrderByDescending(s => s.Age).
    ToPagedList(pageIndex, pageSize); //根據(jù)一熱心博友的建議,加上了這句,點擊相應(yīng)的列,升序降序循環(huán)?!               ?nbsp;ViewBag.CurrentSort = null; 
   }
   else
   {
   lstStudent = db.Set().
    OrderBy(s => s.Age).
    ToPagedList(pageIndex, pageSize);
   }
   break;

  default:
   //如果sortBy==currentSort,就按照對應(yīng)字段降序排列,并分頁。否則升序。
   if (sortBy.Equals(currentSort))
   {
   lstStudent = db.Set().
    OrderByDescending(s => s.Name).
    ToPagedList(pageIndex, pageSize); //根據(jù)一熱心博友的建議,加上了這句,點擊相應(yīng)的列,升序降序循環(huán)?!               ?nbsp;ViewBag.CurrentSort = null; 
   }
   else
   {
   lstStudent = db.Set().
    OrderBy(s => s.Name).
    ToPagedList(pageIndex, pageSize);
   }

   break;
  }
  return View(lstStudent);
 }

 public ActionResult AddStudent()
 {
  return View();
 }

 [HttpPost]
 [ValidateAntiForgeryToken]
 public ActionResult AddStudent(Student model)
 {
  db.Set().Add(model);
  db.SaveChanges();
  return RedirectToAction("Index");
 }
 }
}

創(chuàng)建相對應(yīng)的Index視圖和AddStudent視圖:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

Index視圖:

@using PagedList.Mvc;@*//引入分頁的組件*@
@model PagedList.IPagedList

@{
 ViewBag.Title = "Index";
}
 

Index

 @Html.ActionLink("Create New", "Create")

@using(Html.BeginForm("Index","Employee",FormMethod.Get)) {        @* 通過創(chuàng)建匿名對象,傳遞參數(shù)到控制器中,new { sortBy = "Name", currentSort = ViewBag.CurrentSort }*@   @*參數(shù)的大小寫無所謂,只要和控制器名稱一樣就行,sortBy,currentSort*@   @Html.ActionLink("Name", "Index", new { sortBy = "Name", currentSort = ViewBag.CurrentSort })       @Html.ActionLink("Sex", "Index", new { sortBy = "Sex", currentSort = ViewBag.CurrentSort })       @Html.ActionLink("Email", "Index", new { sortBy = "Email", currentSort = ViewBag.CurrentSort })       @Html.ActionLink("Age", "Index", new {sortBy = "Age", currentSort = ViewBag.CurrentSort })       @foreach (var item in Model) {       @Html.DisplayFor(modelItem => item.Name)       @Html.DisplayFor(modelItem => item.Sex)       @Html.DisplayFor(modelItem => item.Email)       @Html.DisplayFor(modelItem => item.Age)            } }  @*總頁數(shù)是否小于當前頁,小于就說明沒數(shù)據(jù),賦值0,否則賦值PageNumber*@   Page @(Model.PageCount< Model.PageNumber?0:Model.PageNumber) of @Model.PageCount   @Html.PagedListPager(Model, page => Url.Action("Index", new { page}),PagedListRenderOptions.Classic)

AddStudent視圖:

@model PagingAndSortingInMVC.Models.Student

@{
 ViewBag.Title = "AddStudent";
}

AddStudent

@using (Html.BeginForm())  {  @Html.AntiForgeryToken()      
Student
   @Html.ValidationSummary(true, "", new { @class = "text-danger" })     @Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" })      @Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } })   @Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" })   
 
    @Html.LabelFor(model => model.Sex, htmlAttributes: new { @class = "control-label col-md-2" })      @Html.EditorFor(model => model.Sex, new { htmlAttributes = new { @class = "form-control" } })   @Html.ValidationMessageFor(model => model.Sex, "", new { @class = "text-danger" })          @Html.LabelFor(model => model.Email, htmlAttributes: new { @class = "control-label col-md-2" })      @Html.EditorFor(model => model.Email, new { htmlAttributes = new { @class = "form-control" } })   @Html.ValidationMessageFor(model => model.Email, "", new { @class = "text-danger" })          @Html.LabelFor(model => model.Age, htmlAttributes: new { @class = "control-label col-md-2" })      @Html.EditorFor(model => model.Age, new { htmlAttributes = new { @class = "form-control" } })   @Html.ValidationMessageFor(model => model.Age, "", new { @class = "text-danger" })                     }
 @Html.ActionLink("Back to List", "Index")

接著修改一下布局頁:




 
 
 @ViewBag.Title - My ASP.NET Application
 
 
 


 
 
  
  
   
   
   
  
  @Html.ActionLink("Application name", "Index", "Home", new { area = "" }, new { @class = "navbar-brand" })
  
  
  
   @Html.ActionLink("Student List","Index")
   @Html.ActionLink("Add Student ", "AddStudent")
  
  
 
 

 
 @RenderBody()
 
 
  

© @DateTime.Now.Year - My ASP.NET Application

 
     

修改一下默認路由:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;

namespace PagingAndSortingInMVC
{
 public class RouteConfig
 {
 public static void RegisterRoutes(RouteCollection routes)
 {
  routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

  routes.MapRoute(
  name: "Default",
  url: "{controller}/{action}/{id}",
  defaults: new { controller = "Student", action = "Index", id = UrlParameter.Optional }
  );
 }
 }
}


運行項目:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

剛開始沒有任何數(shù)據(jù),我們添加幾條測試數(shù)據(jù):

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

我們來驗證一下,結(jié)果:

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

看到了么,點擊相應(yīng)的列標題就可以進行排序了。分頁也實現(xiàn)了。當然分頁的樣式可以通過改變這個選項:

@Html.PagedListPager(Model, page => Url.Action("Index", new { page}),PagedListRenderOptions.Classic)

這里,我修改了一下

@Html.PagedListPager(Model, page => Url.Action("Index", new { page}),PagedListRenderOptions.TwitterBootstrapPager)

分頁控件的效果就是這樣了。

ASP.NET MVC中怎么實現(xiàn)分頁和排序功能

看完上述內(nèi)容,你們掌握ASP.NET MVC中怎么實現(xiàn)分頁和排序功能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


新聞名稱:ASP.NETMVC中怎么實現(xiàn)分頁和排序功能-創(chuàng)新互聯(lián)
文章源于:http://weahome.cn/article/dehgdd.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部