MVC3学习:利用mvc3+ajax结合MVCPager实现分页

本例使用表格Users(Uid,UserName,PassWord),数据库访问使用EF first code.

   public class Users
    {
        [Key]
        public int Uid { get; set; }
        public string UserName { get; set; }
        public string PassWord { get; set; }
        
    }

第一步:下载MVCPager.dll,添加到引用中。

MVCPager分页控件和AspNetPager分页控件是同一作者:陕西吴起娃,相信以前很多人都用过他的AspNetPager分页控件。MVCPager.dll可到他的个人主页去下载 http://www.webdiyer.com/

第二步:添加命名空间

打开view文件夹中下的web.config,添加两个命名空间。

  <pages pageBaseType="System.Web.Mvc.WebViewPage">
      <namespaces>
        <add namespace="System.Web.Mvc" />
        <add namespace="System.Web.Mvc.Ajax" />
        <add namespace="System.Web.Mvc.Html" />
        <add namespace="System.Web.Routing" />
        <add namespace="Webdiyer.WebControls.Mvc"/>
        <add namespace="ajaxDemo.Models"/>
      </namespaces>
    </pages>

做这一步的目的,是为view文件夹下的所有视图统一添加命名空间,就不需要每一个去单独添加。<add namespace="Webdiyer.WebControls.Mvc"/>这个命名空间,就是MVCPager分页控件的命名空间。<add namespace="ajaxDemo.Models"/>是您的项目下的Models。此处我的项目名称是ajaxDemo。

第三步:制作分部视图

ajax分页,是将数据分好后,放在一个分部视图中,然后再将分部视图放在主视图中。

根据模板,创建一个list的分部视图,我取名为UserPager.cshtml

@model PagedList<Users> //此处需要修改

@*//此表格放入一个DIV中,并设置ID,分页控件中需要用天此ID*@
<div id="data"> 
<table>
    <tr>
        <th>
            用户名
        </th>
        <th>
            密码
        </th>
        <th></th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.UserName)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.PassWord)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new { id=item.Uid }) |
            @Html.ActionLink("Details", "Details", new { id=item.Uid }) |
            @Html.ActionLink("Delete", "Delete", new { id=item.Uid })
        </td>
    </tr>
}
</table>
@*//此处添加分页控件*@
@Html.AjaxPager(
Model,
new PagerOptions { PageIndexParameterName = "page" },
new AjaxOptions { UpdateTargetId = "data" }
)
</div>
View Code

主要修改三个地方:

  1、最开始一行修改为@model PagedList<Users>,Users为您的实体名。

  2、将表格<table>放入到一个div中,并为此DIV设定一个ID,后面放置分页控件时会用到此ID。

  3、在表格<table>的后面,放置分页控件,我设定的分页参数为page,需要分页的区域为data.

至此,分部视图制作完成。

第四步:制作主视图的控制器

我将主视图命名为UserList

 public ActionResult UserList(int? page)
        {
            PagedList<Users> u = db.Users.OrderBy(c=>c.Uid).ToPagedList (page ?? 1, 10);
            if (Request.IsAjaxRequest())
                return PartialView("UserPager", u);
            return View(u);
         }

分页参数是page,是前面放控件时设定好的,默认显示第1页,每页显示10条记录。

注意,在查询数据时,一定要用OrderBy排序,否则会出错。因为作者用的是linq的take和skip函数来进行分页的,用这两个函数前必须要排序。

第五部:制作视图UserList.cshtml

分部视图是不能独立显示的,必须放在其它主视图中显示。此例,我是将分部视图UserPager.cshtml放在主视图UserList.cshtml中显示。

分部视图主要用来分页,主视图主要用来调用分部显示显示数据。

@model PagedList<Users>
@{
    ViewBag.Title = "UserList";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

<h2>用户列表</h2>
@{Html.RenderPartial("UserPager",Model);}

可根据控件器,创建空视图,添加第一行和最后一行,最后一行即是调用分部视图。

至此,分页完成。

原文地址:https://www.cnblogs.com/denny402/p/3162710.html