重构MVC多条件+分页解决方案
为支持MVC的验证,无刷新查询,EF,以及让代码可读性更强一点,所以就重构了下原来的解决方案。
这里就简单讲下使用方法吧:
Model:
继承PagerBase:
1 public class SearchModel : PagerBase
2 {
3 public SearchModel()
4 {
5 AddFields("UserName", "Age", "Sex");
6 }
7
8 [Required(ErrorMessage = "需要输入 用户名")]
9 public string UserName { get; set; }
10 public string Age { get; set; }
11 public string Sex { get; set; }
12
13 public IQueryable<Member> Members { get; set; }
14
15 public override void Search()
16 {
17 int age = 0;
18 if(!Int32.TryParse(Age, out age)) Age = string.Empty;
19 // 过滤
20 Members = Members.Where(UserName, entity => entity.UserName.Contains(UserName))
21 .Where(Age, entity => entity.Age == age)
22 .Where(Sex, entity => entity.Sex == Sex.Trim());
23 // 分页
24 Members = Pager(Members.OrderBy(entity => entity.UserName));
25 }
26 }
SearchModel
View:
分2种,一种是以Get形式刷新地提交查询条件的,分页可以在无刷新与刷新模式之间切换的,优化搜索引擎用的;另一种是无刷新形式提交查询条件的,分页亦是无刷新的。
这里需要将View分成2块,将数据展现的这块独立出来,便于无刷新地展示数据,所以做了个分部视图。
第一种(刷新的):
1 @model MvcPagerSearch.Models.SearchModel
2 @{
3 ViewBag.Title = "Index";
4 }
5
6 <h2>查询</h2>
7 @using(Html.BeginForm("Index", "Search", FormMethod.Get, new { @class = "form-search form-inline", id = "formMain" }))
8 {
9 <div class="input-append">
10 @Html.TextBoxFor(model => model.Age, new { @class = "span2 search-query" })
11 @Html.TextBoxFor(model => model.UserName, new { @class = "span2 search-query" })
12 @Html.TextBoxFor(model => model.Sex, new { @class = "span2 search-query" })
13 <button type="submit" class="btn">
14 快速查询</button>
15 </div>
16 <div data-valmsg-summary="true" class="text-warning"><ul></ul></div>
17 }
18
19 <div class="container">
20 <div id="pager"></div>
21 <div id="Content">
22 @Html.Partial("IndexTable")
23 </div>
24 </div>
25
26 @Url.IncludePagerScript()
27 <script type="text/javascript" src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
28 <script type="text/javascript" src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>
29 <script type="text/javascript">
30 $(function () {
31 $.pager({
32 content: "#Content",
33 pager: "#pager",
34 form: "#formMain",
35 @Html.Raw(Model.Extension),
36 refresh: false
37 });
38 });
39 </script>
Index.cshtml
分页的刷新、无刷新可以通过js中的refresh: false选项来调整
数据展现的分部视图:
1 @model MvcPagerSearch.Models.SearchModel
2 <table class="table table-hover">
3 <thead>
4 <tr>
5 <th>
6 昵称
7 </th>
8 <th>
9 性别
10 </th>
11 <th>
12 年龄
13 </th>
14 </tr>
15 </thead>
16 <tbody>
17 @if(Model.Members != null)
18 {
19 foreach(var entity in Model.Members)
20 {
21 <tr>
22 <td>
23 @entity.UserName
24 </td>
25 <td>
26 @entity.Sex
27 </td>
28 <td>
29 @entity.Age
30 </td>
31 </tr>
32 }
33 }
34 </tbody>
35 </table>
IndexTable.cshtml
第二种(无刷新的):
1 @model MvcPagerSearch.Models.SearchModel
2 @{
3 ViewBag.Title = "Index";
4 }
5
6 <h2>Ajax查询</h2>
7 @using(Html.BeginForm("Index", "AjaxSearch", FormMethod.Post, new { @class="form-search form-inline", id="formMain" }))
8 {
9 <div class="input-append">
10 @Html.TextBoxFor(model => model.Age, new { @class = "span2 search-query" })
11 @Html.TextBoxFor(model => model.UserName, new { @class = "span2" })
12 @Html.TextBoxFor(model => model.Sex, new { @class = "span2" })
13 <button type="submit" class="btn">查询</button>
14 </div>
15 <div data-valmsg-summary="true" class="text-warning"><ul></ul></div>
16 }
17 <div class="container">
18 <div id="pager"></div>
19 <div id="Content">
20 @Html.Partial("IndexTable")
21 </div>
22 </div>
23 @Url.IncludeAjaxPagerScript()
24 <script type="text/javascript" src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
25 <script type="text/javascript" src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>
26 <script type="text/javascript">
27 $(function () {
28 $.ajaxPager({
29 content: "#Content",
30 pager: "#pager",
31 form: "#formMain"
32 });
33 });
34 </script>
Index.cshtml
数据展现的分部视图:
1 @model MvcPagerSearch.Models.SearchModel
2 @Html.Partial("~/Views/Shared/_AjaxPagerPartial.cshtml")
3 <table class="table table-hover">
4 <thead>
5 <tr>
6 <th>
7 昵称
8 </th>
9 <th>
10 性别
11 </th>
12 <th>
13 年龄
14 </th>
15 </tr>
16 </thead>
17 <tbody>
18 @if(Model.Members != null)
19 {
20 foreach(var entity in Model.Members)
21 {
22 <tr>
23 <td>
24 @entity.UserName
25 </td>
26 <td>
27 @entity.Sex
28 </td>
29 <td>
30 @entity.Age
31 </td>
32 </tr>
33 }
34 }
35 </tbody>
36 </table>
IndexTable.cshtml
这里用到了另外个分部视图_AjaxPagerPartial.cshtml,用于记录查询条件与分页信息的。
Control:
2种方式的代码都一样:
1 public class SearchController : Controller
2 {
3 //
4 // GET: /Search/
5 TestContext testContext = new TestContext();
6
7 public ActionResult Index(SearchModel model)
8 {
9 if(ModelState.IsValid)
10 {
11 model.Members = testContext.Members;
12 model.Search();
13 }
14
15 if(Request.IsAjaxRequest()) return PartialView("IndexTable", model);
16 return View("Index", model);
17 }
18 }
SearchController.cs
源代码:http://files.cnblogs.com/nickppa/MvcPagerSearch%E9%87%8D%E6%9E%84.rar
重构MVC多条件+分页解决方案的更多相关文章
- 重构MVC多条件分页解决方案
重构MVC多条件+分页解决方案 为支持MVC的验证,无刷新查询,EF,以及让代码可读性更强一点,所以就重构了下原来的解决方案. 这里就简单讲下使用方法吧: Model: 继承PagerBase: S ...
- asp.net mvc多条件+分页查询解决方案
开发环境vs2010 css:bootstrap js:jquery bootstrap paginator 原先只是想做个mvc的分页,但是一般的数据展现都需要检索条件,而且是多个条件,所以就变成了 ...
- MVC+Bootstrap+Drapper使用PagedList.Mvc支持多查询条件分页
前几天做一个小小小项目,使用了MVC+Bootstrap,以前做分页都是异步加载Mvc部分视图的方式,因为这个是小项目,就随便一点.一般的列表页面,少不了有查询条件,下面分享下Drapper+Page ...
- ASPNETCOREAPI 跨域处理 SQL 语句拼接 多条件分页查询 ASPNET CORE 核心 通过依赖注入(注入服务)
ASPNETCOREAPI 跨域处理 AspNetCoreApi 跨域处理 如果咱们有处理过MV5 跨域问题这个问题也不大. (1)为什么会出现跨域问题: 浏览器安全限制了前端脚本跨站点的访问资源, ...
- Mvc+Dapper+存储过程分页10万条数据
10万条数据采用存储过程分页实现(Mvc+Dapper+存储过程) 有时候大数据量进行查询操作的时候,查询速度很大强度上可以影响用户体验,因此自己简单写了一个demo,简单总结记录一下: 技术:Mvc ...
- AspNetPager 多条件分页查询
AspNetPager 这个分页控件一般做后台基本都知道的,我就不多说了(说明与下载链接:http://www.webdiyer.com/Controls/AspNetPager),嘿嘿!其实我也是刚 ...
- 【java】spring-data-jpa 集成hibernate实现多条件分页查询
初次接触spring-data-jpa,实现多条件分页查询. 基础环境 Spring Boot+spring-data-jpa+hibernate+mysql 1.接口 要继承这个接口,这个接口提供了 ...
- asp.net MVC 常见安全问题及解决方案
asp.net MVC 常见安全问题及解决方案 一.CSRF (Cross-site request forgery跨站请求伪造,也被称为“one click attack”或者session rid ...
- ASP.NET MVC利用PagedList分页(二)PagedList+Ajax+JsRender
(原文) 昨天在ASP.NET MVC利用PagedList分页(一)的 最后一节提到,一个好的用户体验绝对不可能是点击下一页后刷新页面,所以今天来说说利用Ajax+PagedList实现无刷新(个人 ...
随机推荐
- Life of a triangle - NVIDIA's logical pipeline
Home GameWorks Blog Life of a triangle - NVIDIA's logical pipeline Life of a triangle - NVIDIA's l ...
- 详解div+css相对定位和绝对定位用法
1.定位的专业解释: (1)语法 position:static|absolute|fixed|relative 从上面语法可以看出,定位的方法有很多种,它们分别是静态(static),绝对定位(ab ...
- MINIX3
这个系列minix3是好早看的源码 现在都忘记的差不多了 觉得就此扔掉可惜了 今天把他全部放在博客上 1 是想和大家一起讨论下 2 是没事看看 能够加强对一个稳定性系统的理解 加厚
- 原创: How to build a query based on Definition Updates installed
In SCCM 2012 R2, you can use following class. Use SMS_CombinedDeviceResources.EPAntivirusSignatureLa ...
- Bootstrap模态弹出窗
Bootstrap模态弹出窗有三种方式: 1.href触发模态弹出窗元素: <a class="btn btn-primary" data-toggle="moda ...
- Maven 学习-入门
在进行Java开发的过程中,我接触到了Maven这套构建工具.所以,花费了点时间学习了一下这套构建工具,在学习过程中学习到的有关Maven的知识,在这里分享给大家. 什么是Maven 首先,在介绍Ma ...
- drozer安装之夜深模拟器
首先下载drozer的安装包 可以直接到官网下载:https://labs.mwrinfosecurity.com/tools/drozer/ 安装 解压压缩包其中 setup.exe 为Win ...
- 0x00到0xFF二进制数值中1的的个数
似乎有点无聊耶~~~~~(>_<)~~~~ #include <stdio.h> , , , , , , , , , , , , , , , }; ] = { , , , , ...
- 新冲刺Sprint3(第六天)
一.Sprint介绍 商家功能模块继续完善着,加快了工作的步伐. 二.Sprint周期 看板: 燃尽图:
- Enhanced Mitigation Experience Toolkit 软件安全性强化工具
Enhanced Mitigation Experience Toolkit软件是微软为应对互联网中层出不穷的漏洞而推出的一款安全工具,可以在Window Update未获取到补丁前,对系统进行保护. ...