众所周知,asp.net自带的GridView在自带分页方面设计得很2,因为它是假分页,即内存分页。而且它不智能支持强大的Iqueryable。

但这表明微软忽略了现实中的分页需求吗?答案应该不是,我想也不是。

那么,通过什么方式可以达到真分页的效果呢?使用Asp.Net自带的3种DataSource(objectdatasource, entitydatasource, linqdatasource)。 三种datasource各有所长。

但这样做还是有些麻烦呀……

朋友有一个项目,之前数据少,没有考虑过假分页带来的隐患,现在项目也做大了,数据也大了,问题也出来了,怎么办可以实现最少改动呢?废话不多说,直接上代码:

1 自定义一个PageGridView

using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Reflection; namespace DGVTest
{
public class PagingGridView : GridView
{
public PagingGridView()
{ } private IQueryable querableData; public override Object DataSource
{
get
{
return base.DataSource;
}
set
{
if (value is IQueryable)
{
querableData = (IQueryable)value;
ObjectDataSource ods = new ObjectDataSource(); ods.ID = "ods_" + this.ID; ods.EnablePaging = this.AllowPaging;
// This must be the full name of the class
ods.TypeName = "DGVTest.IQueryableAdapter";
ods.SelectMethod = "GetData";
ods.SelectCountMethod = "GetCount";
ods.StartRowIndexParameterName = "startRowIndex";
ods.MaximumRowsParameterName = "pageSize"; ods.EnableViewState = false; ods.ObjectCreating += (o,e)=> e.ObjectInstance =
new IQueryableAdapter(querableData); base.DataSource = ods; if (AllowPaging)
{
PageIndexChanging += (o, gpe) =>
{
PageIndex = gpe.NewPageIndex;
DataBind();
};
}
if (AllowSorting)
{
//---if want to implement sorting...
}
}
else
{
base.DataSource = value;
}
}
}
} public class IQueryableAdapter
{
private IQueryable _data;
private int _totalCount; public IQueryableAdapter(IQueryable data)
{ _data = data;
_totalCount = (int)GetExtMethod("Count", _data ).Invoke(null, new object[] { _data });
} public object GetData()
{
return _data;
} public int GetCount()
{
return _totalCount;
} public object GetData(int startRowIndex, int pageSize)
{
var enumResult = GetExtMethod("Skip", _data).Invoke(null, new object[] { _data, startRowIndex });
return GetExtMethod("Take", _data ).Invoke(null, new object[] { enumResult, pageSize });
} private MethodInfo GetExtMethod(string methodName,object obj )
{
var genType = obj.GetType().GetGenericArguments()[0];
return typeof(System.Linq.Queryable)
.GetMethods(BindingFlags.Public | BindingFlags.Static)
.First(m => m.Name == methodName)
.MakeGenericMethod(genType);
}
}
}

2 把这个新的GridView引入原项目

一般的做法是在页面上添加引用符:

<%@ Register Assembly="DGVTest" Namespace="DGVTest" TagPrefix="juyee" %>

然后把原GridView的前缀改了:

 <juyee:PagingGridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True"></juyee:PagingGridView>

但每个页面都加引用命令,还是很麻烦的。这可以通过在config解决:

  <system.web>
<pages>
<controls>
<add tagPrefix="juyee" namespace="DGVTest"
assembly="DGVTest" />
</controls>
</pages>
</system.web>

有了这个,就不用每个页面加引用命令啦。至于替换gridview的声明嘛,可以用ctrl+F。

3 Code-Behind

现在可以直接把IQueryable类型的对象做为新View的数据源啦。值得一提的是,一定要orderby一下哟,不然执行IQueryable.Skip时会报错。

            var ds= from t in new testdbEntities().People
orderby t.Name
select t; GridView1.DataSource =ds;
GridView1.DataBind();

至此问题解决~赶快试试吧。

[小技巧]让你的GridView支持IQueryable,并自动实现真分页的更多相关文章

  1. 发现一个小技巧:火狐浏览器对phpmyadmin支持更友好

    这段时间ytkah正在迁移服务器(A→B),为了方便起见,直接用phpmyadmin导入数据库.一般我们是用navicat来操作数据库的,但是服务器A设置了权限,无法用navicat连接,只好在浏览器 ...

  2. Linux的95个小技巧

    Linux的95个小技巧 by WEB全栈工程师 on 2012 年 03 月 27 日 这里总结了Linux使用中的一些小技巧 1.实现RedHat非正常关机的自动磁盘修复 先登录到服务器,然后在/ ...

  3. mercurial的几个易用性小技巧

    其实这两年,能够采用mercurial的项目我都尽量用,甚至有些上游是git的,或者需要托管到公司内gitlab上与别人协作的,我都装上hg-git.无它,只是因为mercurial易用性比git好得 ...

  4. MVC 基架不支持 Entity Framework 6 或更高版本 即 NuGet的几个小技巧

    MVC 基架不支持 Entity Framework 6 或更高版本.有关详细信息,请访问 http://go.microsoft.com/fwlink/?LinkId=276833. 原因:mvc版 ...

  5. Android开发的那些坑和小技巧

    1.android:clipToPadding 意思是控件的绘制区域是否在padding里面.默认为true.如果你设置了此属性值为false,就能实现一个在布局上事半功陪的效果.先看一个效果图. 上 ...

  6. Android小技巧

    一.android:clipChildren属性 效果图 看到这个图时你可以先想想如果是你,你怎么实现这个效果.马上想到用RelativeLayout?NO,NO,NO,,, 实现代码 <?xm ...

  7. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  8. iOS:小技巧(不断更新)

    记录下一些不常用技巧,以防忘记,复制用. 1.获取当前的View在Window的frame: UIWindow * window=[[[UIApplication sharedApplication] ...

  9. 最强 Android Studio 使用小技巧和快捷键

    写在前面 本文翻译自 Android Studio Tips by Philippe Breault,一共收集了62个 Android Studio 使用小技巧和快捷键. 根据这些小技巧的使用场景,本 ...

随机推荐

  1. Leaf-spine data center architectures

    http://longwhiteclouds.com/2015/03/26/configuring-scalable-low-latency-l2-leaf-spine-network-fabrics ...

  2. SQL Server 数据库设计

    一.数据库设计的必要性 在实际的软件项目中,如果系统中需要存储的数据量比较大,需要设计的表比较多,表与表之间的关系比较复杂,那我们就需要进行规范的数据库设置.如果不经过数据库的设计,我们构建的数据库不 ...

  3. Windows phone 8 学习笔记(5) 图块与通知(转)

    基于metro风格的Windows phone 8 应用提到了图块的概念,它就是指启动菜单中的快速启动图标.一般一个应用必须有一个默认图块,还可以有若干个次要图块.另外,通知与图块的关系比较密切,我们 ...

  4. poj3122 pie

    方法:二分. 题目意思:要过生日了,我请大家吃pie,然后人数一共是f+1(我自己).每个人的pie不能是拼接的,而且每个人的面积是一样的,这样就用二分枚举. 范围是0-最大的那块pie. 然后用每一 ...

  5. repeater标签双重循环的使用

    在网站开发中,.NET中的repeater标签几乎是笔者首选,也是唯一一个不会生成多余元素的标签,所有样式都是自定义的,这点类似 struts中的<s:iterator/>标签. 在日常编 ...

  6. SubsetsTotal Accepted:49746Total Submissions:176257My Submissions

    Subsets Total Accepted: 49746 Total Submissions: 176257My Submissions Given a set of distinct intege ...

  7. MVC5 Identity 自定义用户和角色

    看代码基本就都能看懂了,增加了两个用户详细信息的表,角色表增加两个字段页面中实现树形显示. //IdentityModels.cs using System.Data.Entity; using Sy ...

  8. PHP二维数组根据某个键名排序

    $result = array( array(           "amount": "11.00",           "date": ...

  9. phpmyadmin误删表后的恢复过程(心惊胆跳啊)

    话说今天不知道是抽风了还是失魂了,在用phpmyadmin删除测试数据时,竟然将整个表删除了: 等程序运行出错时,才出现整个表都没有了,而且之前也没有备份好!这下蛋疼了,这个可是production服 ...

  10. PHP学习之路 (2)

    我们如果坚持用windows做PHP开发,就会错误不断,所以,无论如何都要学习Linux的使用和安装.说实话<鸟哥的linux私房菜>是一本非常不错的书,但是如果你想照着书上面一步一步安装 ...