码迷,mamicode.com
首页 > Web开发 > 详细

asp.net 中使用 pagedlist 分页并具有查询功能的实现方法

时间:2017-03-23 16:09:52      阅读:851      评论:0      收藏:0      [点我收藏+]

标签:stripe   mvc   user   str   实现   控制器   姓名   render   今天   

 用pagedlist在项目中做分页已N次了,今天再次用实例来实现一个带查询功能的分页例子。

1、在view代码:

<div class="search">
    <form method="post" action="/user/index">
        <input placeholder="真实姓名" name="realname" /><button class="btnSearch">查询</button>
    </form>
</div>

<table class="table table-striped">
    <tr>
        <th>
            登录名
        </th>

        <th>
            真实姓名
        </th>
        <th>学校</th>
        <th>年级</th>
        <th>班级</th>
        <th>操作</th>
    </tr>

    @foreach (var item in Model.list)
    {
        <tr data-id="@item.id">
            <td>
                @Html.DisplayFor(modelItem => item.name)
            </td>
            <td>
                @item.realname
            </td>
            <td>
                @item.school
            </td>
            <td>
                @item.stugrade
            </td>
            <td>@item.stuclass</td>
            <td>
                <a href="javascript:;" class="btnResetPwd">重置密码</a> |
                <a href="javascript:;" class="btnDel">删除</a>
            </td>
        </tr>
    }
</table>
@if (Model != null)
{
    <div class="pagedList" style="margin:0 auto;text-align:center">
        @Html.PagedListPager(Model.list, page => Url.Action("index", new { page,realname= Model.curUser.realname }), PagedListRenderOptions.Classic)
    </div>
}

上面注意在查询部分的from表单, name属性中指明后台接收的变量。最下方的是分页代码,注意突出显示部分是在分页时传值的变量名realname= Model.curUser.realnameModel.curUser是后台指定的用户User类的当前用户,这个可以在第二步中具体查看,realname与表单中的一致,保证后台能接收到。

2、MVC控制器

        private OnlineTestEntities db = new OnlineTestEntities();
        private const int pagesize = 15;

       
        public ActionResult Index(User userinfo, int page = 1)
        {
            var list = db.Users.ToList();

            if (!string.IsNullOrEmpty(userinfo.realname))
            {
                list = list.Where(x => x.realname.Contains(userinfo.realname)).ToList();
            }
            UserPagedList mylist = new UserPagedList()
            {
                list = list.OrderByDescending(x => x.id).ToPagedList<User>(page, pagesize),
                curUser = userinfo
            };
            return View(mylist);
        }    

注意红色代码, User中有一属性正是第一步中的realname属性,这是查询条件。UserPagedList  类是把分页集合包装的一个类,是自己写的,如下 :

3、 UserPagedList类:

public class UserPagedList
    {
        public User curUser { get; set; }
        public PagedList.IPagedList<User> list { get; set; }
    }

好了,实现完毕。这种实现现在是我经常用的方法。

asp.net 中使用 pagedlist 分页并具有查询功能的实现方法

标签:stripe   mvc   user   str   实现   控制器   姓名   render   今天   

原文地址:http://www.cnblogs.com/lunawzh/p/6605442.html

(0)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!