asp.net 分页潜谈
要做出分页效果不外乎有这几个方向入手,从数据源、从服务器或者从客户端。不管你是怎么做都跳不出这三个地方(其实B/S结构的开发了就是在这三个地方做文章,只不过有些微变化而已)。
先说说从数据源入手的吧。一想到数据源做分页,自然是T-SQL了。什么存储过程,视图、特殊函数(当然,这里指的只是我熟悉的MS)。能用到的SQL知识都往上砸。具体的实现就不说了,忒Easy。代码部分基本没有什么,只要每次更改T-SQL语句就行了。不好的就是太受数据库的限制,程序中一丁点的变化,所有有关SQL的地方都要变,有些甚至要改变数据库的结构。没有扎实的数据库知识是万万不行了。
服务器端做分页可能是行家们最常用到的方法了。因为有包装好的数据绑定控件啊!拿来就可以用。但是,那么说微软是大佬级人物呢,做个东西都深谋远虑。把菜鸟跟恐龙都考虑在内。你如果是菜鸟就用GridView,内置的分页让你几乎不用写代码就能实现。但如果你是恐龙那就用ListView或DataList等控件,绝对能让你的技术发挥的淋漓尽致。微软为了给这些人个台阶下,就又开发出了DataPager控件。他好像只认IPageableItemContainer接口。紧接着就又有了AspNetPager控件,这就给所有数据绑定控件又一个分页的机会。不过AspNetPager与DataPager不同,AspNetPager只有分页的UI部分,并不能单独完在数据的分页功能。其实大家一定会问,为什么我们不能做自己的分页控件呢?这好像不是微软的原则啊?哈哈,别误会微软。其实早就有这个方法了,只是少有人问津。这就是PagedDataSource。他是没有UI的,微软所有分页的控件都是扩展于他的,包括最早的GridView。有了他,我们就可以随心所欲的做自己的分页控件了。如果把AspNetPager和PagedDataSource结合起来用,那就是如虎添翼。
再说说客户端的分页吧。在以前,客户端做分页无疑就是胖客户端。把所有数据都存到页面,用js控制显示顺序。少量数据还可以忍受,数据一多,那就是谋杀。不过,自从AJAX的出现,改变了这一现象。虽然也少不了的与服务器交互,但总比干等着强吧?这方面.net也表现不错。有了UpdatePanel,一切尽在不言中啊。
以上三个方向都可以很好的完成分页功能,但谁好谁坏也不是我一个人就能决定的,还要看个人的喜好。不过,有一人原则不能忽略,那就是“大道至简,适可而止”。相信,每个人都有自己的一番体会的。
相关推荐
-
asp.net 文章分页显示实现代码
复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) { string str = "事情发生在5月14日晚上23:30分,廊坊师范学院1号楼宿舍发生了恶性打架杀人事件,因1号楼较为复杂,有体育生.英语学院.教育学院等学生住宿,当时情况较为混乱.被害者是一名10级接本的体育生(马上面临毕业)和一名11级教育学院的新生,双方产生 矛盾原因目前不明,当场造成2死1重伤,伤口刀刀致命.其中一人被凶手割断喉部大动脉,未经抢救,当场
-
一个比较通用的分页控件,完整的设计时支持和比较流行的分页模式(提供源码下载)
这是我写的一个分页控件,功能如下: 1.支持设计时支持和两种分页模式,其中综合分页模式的效果如下: 普通分页模式的效果如下: 2.完善的设计时支持,包括自动套用格式和设计时面板设置: 使用方法: 在aspx页面中: 复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="Cyclone.Custo
-
asp.net中用DataReader高效率分页
分享一下两种方式的分页代码 1.用DataReader分页 复制代码 代码如下: /// <summary> /// PageList for DataReader /// </summary> /// <param name="connectionString"></param> /// <param name="sql"></param> /// <param name="p
-
Asp.Net分页和AspNetPager控件的使用
下面就来重点说说这几种分页方式: 一般情况下我们都是通过sql语句来分页,这在无论哪种开发语音都是通用的, 使用sql语句或者存储过程分页的方式最主要的是要在读取数据的时候把sql语句或者存储过程写好,它的原理是只读取当前要显示的几行记录,所以要根据页数和每页显示的数目来写语句,如下: Select top pageSize * from News where id not in(select top (Page-1)*pageSize id from News) 很显然只要将pageSize和
-
asp.net分页控件AspNetPager的样式美化
在前段时间的开发网站的过程中,突然觉得这个简洁的样式看着和网站整体的风格实在不搭调,于是看看AspNetPager的最后生成html,写了一段CSS样式,将分页的样式和网站整体风格统一起来了. 效果如下: 做的不是很好看,希望大家不要丢砖头,俺的头没包棉絮,伤不起 ~-_-~ CSS样式表: /* AspNetPager Style Power By http://www.edweb.cn */.pager{ width:95%; margin:10px; line-height:20px;
-
asp.net 分页潜谈
要做出分页效果不外乎有这几个方向入手,从数据源.从服务器或者从客户端.不管你是怎么做都跳不出这三个地方(其实B/S结构的开发了就是在这三个地方做文章,只不过有些微变化而已). 先说说从数据源入手的吧.一想到数据源做分页,自然是T-SQL了.什么存储过程,视图.特殊函数(当然,这里指的只是我熟悉的MS).能用到的SQL知识都往上砸.具体的实现就不说了,忒Easy.代码部分基本没有什么,只要每次更改T-SQL语句就行了.不好的就是太受数据库的限制,程序中一丁点的变化,所有有关SQL的地方都要变,有些
-
ASP.Net分页的分页导航实例
Asp.Net分页可以设置分页的首页.上一页.下一页.尾页在前台显示的链接文本.这里只是提及简单功能,深入研究剖析其原理就更得心应手了. //containerId 导航的目标容器,建议使用span标签 //url 默认为XXX.XX?pagenum= //curPage 当前的页码 //maxSection 最大的分段数(一段里面最大的页数) //totalPage 总共的页数 function Navigate(containerId,url,curPage,maxSection, tota
-
ASP经典分页类
ASP经典分页类 出处 '===================================================================== 'XDOWNPAGE ASP版本 '版本 1.00 'Code by zykj2000 'Email: zykj_2000@163.net 'BBS: http://bbs.513soft.net '本程序可以免费使用.修改,希望我的程序能为您的工作带来方便 '但请保留以上请息 ' '程序特点 '本程序主要是对数
-
asp.net分页控件使用详解【附实例下载】
一.说明 AspNetPager.dll这个分页控件主要用于asp.net webform网站,现将整理代码如下 二.代码 1.首先在测试页面Default.aspx页面添加引用 <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix="webdiyer" %> 2.写一个Repeater列表控件用于显示数据 <asp:Repeater ID
-
超级ASP大分页_我的类容我做主
超级ASP大分页_我的类容我做主 选择自 AppleBBS 的 Blog 关键字 超级ASP大分页_我的类容我做主 出处 <% '=================================================================== 'ShowMorePage ASP版本 'Version HuangJM1.00 'Code by maomao 'Create Date 2004-09-28 'QQ:5144707 'http:
-
ASP通用分页样式函数代码
<% '****************************** '函数:MultiPage(Numbers,Perpage,Curpage,Url_Add) '参数:Numbers,总记录数:Perpage,每页记录数:Curpage,当前页:Url_Add,当前页其它参数如?action=list& '作者:阿里西西 '日期:2007/7/15 '描述:ASP通用分页样式函数 '示例:MultiPage(100,10,2,"?action=list&")
-
[Asp.Net Core] 浅谈Blazor Server Side
在2016年, 本人就开始了一个内部项目, 其特点就是用C#构建DOM树, 然后把DOM同步到浏览器中显示. 并且在一些小工程中使用. 3年下来, 效果很不错, 但因为是使用C#来构建控件树, 在没有特定语法的情况下, 代码风格不是那么好. 典型的风格大概是这样的: 这个模式挺好的, 有点嫌弃C#代码占比太高, HTML代码靠字符串来完成, 在界面的设计上, 比较吃力. 在2019年秋, Asp.Net 3.0出来了, Blazor Server Side 也正式公布, 可以在VS2019中使用
-
创建一个ASP通用分页类
从开始学习到使用ASP到现在也写了不少程序了,最令人头痛的是写数据分页,每次都是由于几个变量名或几个参数的不同,因而需要每次都写哪一段冗长而又繁杂的分页代码,代码长了使得程序的可读性变差,容易出差,调试半天也找不出错在哪里,所以慢慢的我开始使用一些网上的提供的分页函数或分页类.的确省事不少,但是通常的函数和类的做法都是就数据显示部分也封装了起来,每次为了达到自己需要的显求效果要去改动函数或者类的本身,所以使用起来也不是怎么方便,自己写的分页改起来已经够复杂了,更不要说别人的了. 所以趁昨天有空自
-
asp.net分页功能实现
说一下实现分页的思路 这里的分页用到了一个组件 AspNetPage.dll,这个组件大家可以到网上去下载,我这里就不提供了 添加最近到工具箱中这样我们就可以像其他控件一样拖拽使用了 如图DataPage是在工具箱中的,至于怎么添加你们百度吧 拖拽到页面中如图 这个是我加完样式后显示的效果,怎么样是不是你们想要的了,如果不是你们还可以修改样式样式稍候奉上 先来看看要怎么使用 <webdiyer:AspNetPager ID="AspNetPager1" runat="s
-
XDOWNPAGE ASP版本 分页类
<% '=================================================================== 'XDOWNPAGE ASP版本 '版本 1.00 'Code by zykj2000 'Email: zykj_2000@163.net 'BBS: http://bbs.513soft.net '本程序可以免费使用.修改,希望我的程序能为您的工作带来方便 '但请保留以上请息 ' '程序特点 '本程序主要是对数据分页的部分进行了封装,
随机推荐
- linux重启和关闭系统命令的写法
- CentOS 6.5源码安装Erlang教程
- jQuery中创建实例与原型继承揭秘
- 总结JavaScript的正则与其他语言的不同之处
- linux的最大打开文件数限制修改方法
- linux ssh 别名登录小技巧
- spring batch 读取多个文件数据导入数据库示例
- wxPython框架类和面板类的使用实例
- windows7配置Nginx+php+mysql的详细教程
- Codeigniter出现错误提示Error with CACHE directory的解决方案
- Android中bindService基本使用方法概述
- 介绍Python中内置的itertools模块
- linux下vi命令介绍
- Ruby Gems更换淘宝源方法
- Jquery+Ajax+Json+存储过程实现高效分页
- JS实现的自定义显示加载等待图片插件(loading.gif)
- android实现ViewPager的Indicator的实例代码
- 关于CentOS 7下sqlite3找不到的问题解决
- Java中的数组基础知识学习教程
- C++设计模式之职责链模式