前几天做一个小小小项目,使用了MVC+Bootstrap,以前做分页都是异步加载Mvc部分视图的方式,因为这个是小项目,就随便一点。一般的列表页面,少不了有查询条件,下面分享下Drapper+PagedList.Mvc支持多查询条件分页的使用经验。

构建强类型Model

1.查询参数的Model

    public class OrderQueryParamModel
{
/// <summary>
/// 订单编号
/// </summary>
public string OrderNo { get; set; } /// <summary>
/// 客户名称
/// </summary>
public string CustomerName { get; set; }
}

2.Orders分页数据Model

PagedList提供了一个StaticPagedList<T>泛型类来封装数据。(看看StaticPagedList的源代码,使用非常方便,把T类型的数据subset,pageNumber,pageSize,totalCount初始化进去就可以了。

 public StaticPagedList(IEnumerable<T> subset, IPagedList metaData) : this(subset, metaData.PageNumber, metaData.PageSize, metaData.TotalItemCount)
{
}

3.Orders展示页面整体Model

    public class OrderViewModel
{
public OrderQueryParamModel QueryModel { get; set; } public PagedList.StaticPagedList<OrderModel> OrderList { get; set; }
}

OK,接下来看看在Controller中如何给来OrderViewModel填充数据吧

        public ActionResult List(OrderViewModel orderViewModel, int page = )
{
var pagesize = ;
var count = ; var orders = _orderService.GetOrders(page, pagesize, orderViewModel.QueryModel, ref count); orderViewModel.OrderList = new StaticPagedList<OrderModel>(orders, page, pagesize, count); return View(orderViewModel);
}

Controller中代码很简单,接收POST过来的两个参数,orderViewModel:包含查询参数Model,page:PagedList定义的当前页。

顺便看看GetOrders()这个方法吧,为了省事懒得写存储过程,直接用了Drapper的QueryMultiple,感觉很强大啊。

        public List<OrderModel> GetOrders(int pageindex, int pagesize, OrderQueryParamModel query, ref int count)
{
var orders = new List<OrderModel>();
var whereStr = string.Empty; if (query != null)
{
if (!string.IsNullOrEmpty(query.CustomerName))
{
whereStr += string.Format(" and CustomerName like '%{0}%' ", query.CustomerName);
}
} var cmd = string.Format(@"SELECT COUNT(*) FROM [Orders] WHERE 1=1 {0};
SELECT * FROM (
SELECT *, row_number() OVER (ORDER BY orderId DESC ) AS [row]
FROM [Orders] WHERE 1=1 {0} )t
WHERE t.row >@indexMin AND t.row<=@indexMax", whereStr); using (IDbConnection conn = BaseDBHelper.GetConn())
{
using (var multi = conn.QueryMultiple(cmd,
new { indexMin = (pageindex - ) * pagesize, indexMax = pageindex * pagesize }))
{
count = multi.Read<int>().SingleOrDefault();
orders = multi.Read<OrderModel>().ToList();
}
}
return orders;
}

这里要注意下的是,multi.Read的顺序必须和Sql查询出来的数据集合顺序一样。

前端数据展示

1.首先在View中添加引用

@using PagedList.Mvc;
@using PagedList;
@model Models.OrderViewModel 

2.为查询创建一个表单

<div class="page-header">

    @using (Html.BeginForm("List", "Order", FormMethod.Post, new { id = "OrderForm", @class = "form-horizontal" }))
{
@Html.Raw("客户名称:") @Html.TextBoxFor(m => m.QueryModel.CustomerName)
@Html.Raw("订单编号:") @Html.TextBoxFor(m => m.QueryModel.OrderNo) <button type="submit" class="btn btn-purple btn-sm">查询</button> //咿,这个干吗用的?后面会解释
<input type="hidden" name="page" value="" />
}
</div>

3.绑定数据

<table class="table loading table-bordered margin-top-5 margin-bottom-5">
<thead>
<tr>
<th>订单编号</th>
<th>客户名称</th>
<th>手机号码</th>
<th>商品数量</th>
<th>订单金额</th>
<th>下单时间</th>
</tr>
</thead>
<tbody> @foreach (var item in Model.OrderList)
{
<tr>
<td>@item.orderNo</td>
<td>@item.customerName</td>
<td>@item.customerMobile</td>
<td>@item.productQuantity</td>
<td>@item.orderAmount</td>
<td>@item.orderCreateTime</td>
</tr>
}
</tbody>
</table>

4.绑定分页插件数据

@if (Model.OrderList != null&&Model.OrderList.Any())
{
<div class="pagedList" style="margin:0 auto;text-align:center">
@Html.PagedListPager(Model.OrderList, page => Url.Action("List", new { page }), PagedListRenderOptions.Classic)
</div>
}

OK,一切搞定了,运行你会发现,分页导航生成的链接都是 "/Order/List/2" 这种形式,无法支持我们把其他查询参数也传递到Controller。

我们换一个思路,为什么不把page这个参数放到form表单去了?  还记得我们form中有一个name=page 的hidden input吧?

    $(function () {

        $(".pagination > li > a").click(function () {

            event.preventDefault();

            var index = $(this).html();

            if (index == '»') {
index = parseInt($(".pagination > li[class=active] > a").html()) + 1;
}
if (index == '«') {
index = parseInt($(".pagination > li[class=active] > a").html()) - 1;
} if (index < 1) return; $("input[name=page]").val(index);
$("#OrderForm").submit();
}); });

通过这段JS,直接把原来分页的a标签作废了,获取他的page值放到了form中,然后直接触发form的submit(),这样就满足了我们一般的查询业务需求。

本文博客园地址:http://www.cnblogs.com/struggle999/p/6918524.html

MVC+Bootstrap+Drapper使用PagedList.Mvc支持多查询条件分页的更多相关文章

  1. MVC客户管理(添加、修改、查询、分页)

    ASP.NET MVC搭建项目后台UI框架—6.客户管理(添加.修改.查询.分页)   目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2 ...

  2. KnocoutJs+Mvc+BootStrap 学习笔记(Mvc)

    Mvc   1.Html 增加扩展方法 using System.Web.Mvc; namespace KnockoutBootstrapMvc.Entensions { public static ...

  3. 再谈使用X.PagedList.Mvc 分页(ASP.NET Core 2.1)

    在以前的博文中写过使用X.PagedList.Mvc组件来对ASP.NET MVC应用程序进行分页,可以参考此篇随笔:Asp.net MVC 使用PagedList(新的已更名 为X.PagedLis ...

  4. MVC Bootstrap极速开发框架

    ASP.NET MVC Bootstrap极速开发框架 前言 每次新开发项目都要从头开始设计?有木有一个通用的快速开发框架?并且得是ASP.NET MVC  And Bootstrap?数据库不要手工 ...

  5. SpringMVC Hibernate+Spring+Spring MVC+Bootstrap的管理系统实现

    SpringMVC学习系列(12) 完结篇 之 基于Hibernate+Spring+Spring MVC+Bootstrap的管理系统实现 到这里已经写到第12篇了,前11篇基本上把Spring M ...

  6. 使用EF+ASP.NET MVC+Bootstrap开发一个功能强大的问卷调查系统

    功能简介 支持七大题型 下拉选择题.单选题.多选题.填空题.数字题.问答题.组合/矩阵题(单选组合.多选组合.填空组合.数字组合) 题库支持 每个问卷都要设置姓名.年龄.性别.学历,怎么办?题库帮您轻 ...

  7. Asp.net MVC 使用PagedList(新的已更名 为X.PagedList.Mvc) 分页

    在asp.net mvc 中,可以bootstrap来作为界面,自己来写分页程序.也可以使用PagedList(作者已更名为 X.PagedList.Mvc)来分页. 1.首先,在NuGet程序包管理 ...

  8. Asp.Net MVC+BootStrap+EF6.0实现简单的用户角色权限管理

    这是本人第一次写,写的不好的地方还忘包含.写这个的主要原因是想通过这个来学习下EF的CodeFirst模式,本来也想用AngularJs来玩玩的,但是自己只会普通的绑定,对指令这些不是很熟悉,所以就基 ...

  9. 分享基于EF+MVC+Bootstrap的通用后台管理系统及架构

      基于EF+MVC+Bootstrap构建通用后台管理系统,集成轻量级的缓存模块.日志模块.上传缩略图模块.通用配置及服务调用, 提供了OA.CRM.CMS的原型实例,适合快速构建中小型互联网及行业 ...

随机推荐

  1. 跟着刚哥梳理java知识点——异常(十一)

    异常:将程序执行中发生的不正常情况(当执行一个程序时,如果出现异常,那么异常之后的代码就不在执行.) java.lang.Throwable:异常的超类 1.Error:java虚拟机无法解决的严重问 ...

  2. React组件实现越级传递属性

    如果有这样一个结构:三级嵌套,分别是:一级父组件.二级子组件.三级孙子组件,且前者包含后者,结构如图: 如果把一个属性,比如color,从一级传递给三级,一般做法是使用props逐一向下传递,代码如下 ...

  3. 讨论LSTM和RNN梯度消失问题

      1RNN为什么会有梯度消失问题 (1)沿时间反向方向:t-n时刻梯度=t时刻梯度* π(W*激活函数的导数)  

  4. java面试题(二)

    21.描述一下JVM加载class文件的原理机制? 答:JVM中类的装载是由类加载器(ClassLoader)和它的子类来实现的,Java中的类加载器是一个重要的Java运行时系统组件,它负责在运行时 ...

  5. mac终端ssh连接服务器 空闲的时候 连接断开

    ssh_config详解(MAC OSX) 方法1:MAC客户端配置 配置“/etc/ssh/ssh_config”文件 “/etc/ssh/ssh_config” 文件是OpenSSH系统范围的配置 ...

  6. [进程管理]Linux进程状态解析之R、S、D

    Linux是一个分时操作系统,能够在一个cpu上运行多个程序,每个被运行的程序实例对应一个或多个进程,这里介绍一下Linux进程状态. Linux是一个多用户,多任务的系统,可以同时运行多个用户的多个 ...

  7. 【转】10 条提升 Android 性能的建议

    每个人都知道一个 App 的成功,与这个 App 的性能体验有着很密切的关系.但是如何让你的 App 拥有极致性能体验呢?在 DroidCon NYC 2015 的这个分享里,Boris Farber ...

  8. 阿里云主机试用之自建站点和ftp上传所遇的2个问题

    1.Access to the requested object is only available from the local network 其实我并没有自建站点,只是使用了XAMPP来建了ap ...

  9. IOS的UIPickerView 和UIDatePicker

    1.UIPickerView的常见属性 //数据源(用来告诉UIPickerView有多少列多少行) @property(nonatomic,assign) id<UIPikerViewData ...

  10. 添加本地jar包到本地的Maven仓库以及在Maven仓库中搜索想要添加的jar包

    今天在学习Memacached的时候,将java_memcached-release下载下来,要使用maven来集成相关的jar包,Memcached的jar包如下: java_memcached-r ...