- 浏览: 618466 次
- 性别:
- 来自: 卡哇伊
-
文章分类
- 全部博客 (299)
- C# (25)
- Java (1)
- WinForm (0)
- Asp.Net (86)
- Jsp (2)
- Php (1)
- Web Service (0)
- Desgin Patterns (19)
- Data Structure & Algorithms (1)
- SQLserver (41)
- Mysql (0)
- Oracle (2)
- Javascript (50)
- Ajax (10)
- Jquery (1)
- Flex (0)
- Regular Expression (5)
- DIV+CSS+XHTML+XML (18)
- Software Test (0)
- Linux (0)
- Utility (17)
- Net Digest (4)
- windows 2003 (10)
- Other (4)
- English (1)
- IT Term (1)
最新评论
-
w497480098h:
学习了 很好谢谢
SQL Server下无限多级别分类查询解决办法(简单查询树形结构数据库表) -
main_fun:
确实不错
iframe自适应高度 -
jveqi:
...
DBA -
mxcie:
其它版本没有确认,今天使用vs2003时,其.sln文件也需要 ...
彻底删除项目的VSS源代码管理信息 -
moneyprosper:
就只有IE支持,火狐和谷歌都不支持此种方法。正在寻找中。。。
从父页面读取和操作iframe中内容方法
做一个项目,用到了DATALIST,由于分页的需求,手动写了分页的函数。个人觉得GOOGLE的分页很不错,上网查了下资料,修改了下。
这里没有涉及到数据的分页读取,只是返回一个带HTML代码的分页样式(字符串),可以用label在页面显示,也可以用this.Controls.Add(new LiteralControl(string));方法加入到页面控件中。
Demo1:
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using System.Text; /// <summary> /// Pagenumber 的摘要说明 /// </summary> public static class Pagenumber { /// <summary> /// 创建并显示分页器 /// </summary> public static string BuildPager(int totalRecords, int currentPage, int pageSize, int pid) { int alter = 4; int startPage = 1; int endPage = currentPage + alter; int totalPages = CalculateTotalPages(totalRecords, pageSize); if (currentPage > alter) { startPage = currentPage - alter; } if (endPage > totalPages) { endPage = totalPages; } string strTemp = @" <a href='Default.aspx?p={0}&pno={1}'>{2}</a> "; StringBuilder sb = new StringBuilder(""); if (currentPage != startPage) { sb.Append(string.Format(strTemp, currentPage - 1, currentPage - 1, " 上一页 ")); } for (int i = startPage; i <= endPage; i++) { if (currentPage == i) { sb.Append(" <font color=red> " + i + " </font> "); } else { sb.Append(string.Format(strTemp, i, i, "[" + i + "]")); } } if (currentPage != endPage) { sb.Append(string.Format(strTemp, currentPage + 1, currentPage + 1, " 下一页 ")); } return sb.ToString(); } /**/ /// <summary> /// 计算总页数 /// </summary> /// <param name="totalRecords"> 总记录数 </param> /// <param name="pageSize"> 每页记录数 </param> public static int CalculateTotalPages(int totalRecords, int pageSize) { int totalPagesAvailable; totalPagesAvailable = totalRecords / pageSize; // 由于C#的整形除法 会把所有余数舍入为0,所以需要判断是否需要加1 if ((totalRecords % pageSize) > 0) totalPagesAvailable++; return totalPagesAvailable; } }
Demo2:
/**//// <summary> /// 类似GOOGLE的分页函数,王传炜,资料参考http://www.phpx.com/happy/viewthread.php?tid=99280&extra=&page=2,谢谢YourEyes /// </summary> /// <param name="total">总记录数</param> /// <param name="per">每页记录数</param> /// <param name="page">当前页数</param> /// <param name="query_string">Url参数</param> private string pagination(int total,int per,int page,string query_string) { int allpage=0; int next=0; int pre=0; int startcount=0; int endcount=0; string pagestr=""; if(page<1){page=1;} //计算总页数 if (per != 0) { allpage = (total / per); allpage = ((total % per) != 0 ? allpage + 1 : allpage); allpage = (allpage == 0 ? 1 : allpage); } next=page+1; pre=page-1; startcount=(page+5)>allpage?allpage-9:page-4;//中间页起始序号 //中间页终止序号 endcount = page<5 ? 10 : page+5; if(startcount<1) {startcount=1;} //为了避免输出的时候产生负数,设置如果小于1就从序号1开始 if(allpage<endcount){endcount=allpage;}//页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内 pagestr="共"+ allpage +"页 "; pagestr+=page>1 ? "<a href=\""+ query_string + "?page=1\">首页</a> <a href=\""+ query_string +"?page="+ pre +"\">上一页</a>": "首页 上一页"; //中间页处理,这个增加时间复杂度,减小空间复杂度 for(int i=startcount;i<=endcount;i++) { pagestr+=page==i?" <font color=\"#ff0000\">"+i+"</font>":" <a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>"; } pagestr+=page!=allpage ? " <a href=\""+ query_string+"?page="+ next +"\">下一页</a> <a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页"; return pagestr; }
如果再加上 分页存储过程 就可以满足大部分需求了。
一个分页存储过程
在这里整理了两个可以用的分页存储过程,以备后用。
第一:
ALTER procedure Consignment @tablename varchar(80) , @strOrder varchar(50) , @PageIndex int = 1, @PageSize int = 15, @strGetFields varchar(200) = '*', @OutPut int output as Begin Declare @strSql varchar(500) DECLARE @SQL NVARCHAR(1000) DECLARE @R BIGINT SET @SQL= N'select @R=count(*) from '+@TableName EXEC SP_EXECUTESQL @SQL, N' @R BIGINT OUTPUT', @R OUTPUT SET @OutPut= @R if(@PageIndex =1) Begin set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' order by '+@strOrder End Else set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' where ('+@strOrder +' >= ( select Max('+@strOrder+') from ( select top '+str(@PageSize*@PageIndex)+' * from '+@tablename+' order by ' +@strOrder+' ) as tempTable)) order by '+ @strOrder select @strSql exec(@strSql) End
第二:
alter procedure AllProce
@tablename varchar(200) , --表名
@strGetFields varchar(200) = '*', --查询列名
@PageIndex int = 1 , --页码
@pageSize int = 15, --页面大小
@strWhere varchar(100) = '', --查询条件
@strOrder varchar(100) = '', --排序列名
@intOrder bit = 0, --排序类型 1为升序
@CountAll bigint output --返回纪录总数用于计算页面数
as
begin
declare @strSql varchar(500) --主语句
declare @strTemp varchar(100) --临时变量
declare @strOrders varchar(50) --排序语句
declare @table varchar(70)
declare @SQL nvarchar(1000)
declare @R bigint
set @SQL= N'select @R=count(*) from '+convert(nvarchar(200),@TableName)
exec SP_EXECUTESQL @SQL, N' @R BIGINT OUTPUT', @R OUTPUT
set @CountAll= @R
if @intOrder = 0
begin
--为0是升序
set @strTemp = '>(select max'
set @strOrders = ' order by '+@strOrder+' asc '
end
else
begin
--否则为降序
set @strTemp = '<(select min'
set @strOrders = ' order by '+@strOrder+' desc '
end
if @PageIndex =1 --第一页直接读出纪录
begin
if @strWhere = ''
begin
set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' '+@strOrders
end
else
begin
set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+ ' from '+@tablename+' where '+@strWhere+' '+@strOrders
end
end
else
begin
set @strSql = 'select top'+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strOrder+' '+@strTemp+' ('+@strOrder+')'
+' from (select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+ ' '+@strOrders+ ') as tempTable ) '+@strOrders
if @strWhere != ' '
begin
set @strSql = 'select top '+str(@pageSize)+ ' '+@strGetFields+' from '+@tablename+ ' where '+@strOrder+ ' '+@strTemp+' ('+@strOrder+') '
+' from(select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strWhere+' ' +@strOrders+') as tempTable) where '+@strWhere+' '+@strOrders
end
end
exec(@strSql)
end
GO
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lcfgaoyong/archive/2006/04/20/670806.aspx
发表评论
-
JS操作RadioButtonList
2009-12-16 23:25 3915function IsUpPic() { ... -
asp.net跳转页面的三种方法比较
2009-10-22 14:16 25591.Response.redir ... -
ASP.NET网站中的安全问题
2009-10-20 16:57 1205在网络经常看到网站被 ... -
新闻内容页分页的简单做法
2009-10-10 10:08 1232该例子只是提供了基本思路 很简单的做法,这个是假设数 ... -
Asp.net控件开发学习笔记(二)-控件开发基础
2009-10-03 16:49 1356接上篇…….. 看System.Web.UI.Ht ... -
Asp.net控件开发学习笔记-控件开发基础(一)
2009-10-03 16:33 1261服务器控件开发基础 当开发一个服务器控件时,首 ... -
Asp.net用户退出,清空Session,重定向登陆页面
2009-09-28 16:22 4192protected void Page_Load(object ... -
frameset中的aspx无法Postback
2009-09-28 16:07 1515<frameset cols="150,*&q ... -
.net页面定时刷新的几种简单方式
2009-09-28 11:20 59451: window.setTimeout("win ... -
动态添加TextBox
2009-09-21 16:30 1711方法1: 前台代码: <f ... -
浅谈ASP.NET管道优化
2009-09-20 21:43 1025ASP.NET管道优化 位于请求管道中的很多ASP.NET默 ... -
Asp.net 页面返回到上一页面
2009-09-20 21:20 937/// <summary> / ... -
PrecompiledApp.config文件和Global.asax 文件中的事件的关联
2009-09-19 10:24 2807在用Microsoft Visual Studio 2005开 ... -
gridview列 数字、货币和日期 显示格式
2009-09-11 17:05 1551在设置gridview等数据绑定控件的模版列时,总要 ... -
ASP.NET 打开新窗口几种方法
2009-09-09 21:44 3365ASP.NET打开新窗口方法一: Response ... -
response.addHeader("Content-Disposition","attachment; filename="+filename)中的中文乱码
2009-08-31 15:10 3293两种解决方法 1.如果web.config里utf-8 直接S ... -
技巧和诀窍:如何在VS 2005 SP1中使用VS的web服务器运行一个相对于根目录“/”的网站
2009-08-31 08:29 879大家常有一个疑问,是 ... -
Request.ServerVariables详细说明及代理
2009-08-14 10:46 2168ServerVariables是环境变量的集合。允许读取HTT ... -
DataList和Repeat无数据时提示暂无数据几种方法
2009-08-11 18:45 25821.放一个label DataTable table ... -
Asp.Net中清空所有textbox的几种方法
2009-08-08 08:53 5212用反射: FieldInfo[] info ...
相关推荐
在这个项目中,我们关注的是“datalist2种分页样式源码源数据库”,它提供了两种分页样式:数字分页,模仿了百度和Google的分页效果,并且附带了源代码和源数据库。这个解决方案旨在实现一个无需额外控件的分页功能...
* description:超强分页类,四种分页模式,默认采用类似baidu,google的分页风格。 * 2.0增加功能:支持自定义风格,自定义样式,同时支持PHP4和PHP5, * to see detail,please visit ...
AutoCompleteTextBox是.NET框架中一个非常实用的控件,它为用户提供了一种自动补全功能,类似于我们在使用百度或Google搜索引擎时输入关键字时看到的智能提示。这种功能能够提高用户体验,减少用户输入,并且在大量...
99.谷歌及百度站点提交向导 100.脚本调用,可用js的方式站外调用 101.自定义幻灯片样式功能,在后台一键切换 102.前台内容页面可打印 103.可以推荐内容给好友 ===========================================...
数据操作工具类(ToolData.java),自动递归获取表单数据封装成Map、本地数据分页共通方法等 图片操作工具类(ToolPicture.java),生成二维码、验证码、灰度、合成、圆角、水印等操作 读取本地资源工具类...