JQuery实现分页程序代码,源码下载
2013-07-29 10:38
513 查看
Web开发,分页在所难免的,微软GridView、AspPager等设置分页数据可以自动分页,但是这里浏览器会闪动,用户体验不是很友好,在此我整理了JQuery实现分页,并且使用
JQuery模板显示数据,用户体验很友好
项目结构:
View Code
最后的效果是,如下图
代码基本上写好了,希望对大家有用,一起学习,一起进步
源码下载:http://pan.baidu.com/share/link?shareid=2604334191&uk=2920032010
JQuery模板显示数据,用户体验很友好
项目结构:
public class PageBar { /// <summary> /// 完整模式:数字+上下页+首末+总记录信息+指定页码翻转 /// </summary> /// <param name="stype"></param> /// <param name="stepNum"></param> /// <param name="pageRoot"></param> /// <param name="pageFoot"></param> /// <param name="countNum"></param> /// <param name="currentPage"></param> /// <param name="Http1"></param> /// <param name="HttpM"></param> /// <param name="HttpN"></param> /// <param name="limitPage"></param> /// <returns></returns> private static string GetDetailbar(string stype, int stepNum, int pageRoot, int pageFoot, int pageCount, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage) { StringBuilder sb = new StringBuilder(); sb.Append("<div class='p_btns'>"); //sb.Append("<span class='total_count'>共" + countNum.ToString() + "条,当前第" + currentPage.ToString() + "/" + pageCount.ToString() + "页 </span>"); sb.Append("<span class='total_count'>共" + countNum.ToString() + "条记录/" + pageCount.ToString() + "页 </span>"); if (countNum > pageSize) { if (currentPage != 1)//只要不是第一页 sb.Append("<a target='_self' href='" + GetPageUrl(currentPage - 1, Http1, HttpM, HttpN, limitPage) + "' title='上一页'>«</a>"); if (pageRoot > 1) { sb.Append("<a target='_self' href='" + GetPageUrl(1, Http1, HttpM, HttpN, limitPage) + "'>1..</a>"); } if (stepNum > 0) { for (int i = pageRoot; i <= pageFoot; i++) { if (i == currentPage) sb.Append("<span class='currentpage'>" + i.ToString() + "</span>"); else sb.Append("<a target='_self' href='" + GetPageUrl(i, Http1, HttpM, HttpN, limitPage) + "'>" + i.ToString() + "</a>"); if (i == pageCount) break; } } if (pageFoot < pageCount) { sb.Append("<a target='_self' href='" + GetPageUrl(pageCount, Http1, HttpM, HttpN, limitPage) + "'>.." + pageCount + "</a>"); } if (currentPage != pageCount)//只要不是最后一页 sb.Append("<a target='_self' href='" + GetPageUrl(currentPage + 1, Http1, HttpM, HttpN, limitPage) + "' title='下一页'>»</a>"); if (stype == "html") sb.Append("<span class='jumppage'>转到第 <input type='text' name='custompage' size='2' onkeyup=\"this.value=this.value.replace(/\\D/g,'')\" onafterpaste=\"this.value=this.value.replace(/\\D/g,'')\" onkeydown=\"if(event.keyCode==13) {window.location='" + HttpN + "'.replace('<#page#>',this.value); return false;}\" /> 页</span>"); } sb.Append("</div>"); return sb.ToString(); } /// <summary> /// 分页导航 /// </summary> /// <param name="mode">支持1=simple,2=normal,3=full</param> /// <param name="stype">html/js,只有当stype为html且mode为3的时候显示任意页的转向</param> /// <param name="stepNum">步数,如果步数为i,则每页的数字导航就有2i+1</param> /// <param name="countNum">记录总数</param> /// <param name="pageSize">每页记录数</param> /// <param name="currentPage">当前页码</param> /// <param name="Http1">第1页的链接地址模板,支持js</param> /// <param name="HttpM">第M页的链接地址模板,支持js,M不大于limitPage</param> /// <param name="HttpN">第N页的链接地址模板,支持js,N大于limitPage</param> /// <param name="limitPage"></param> /// <returns></returns> public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage) { string pagebar = ""; //if (countNum > pageSize) //{ int pageCount = countNum % pageSize == 0 ? countNum / pageSize : countNum / pageSize + 1; currentPage = currentPage > pageCount ? pageCount : currentPage; currentPage = currentPage < 1 ? 1 : currentPage; int stepageSize = stepNum * 2; int pageRoot = 1; int pageFoot = pageCount; pageCount = pageCount == 0 ? 1 : pageCount; if (pageCount - stepageSize < 1)//页数比较少 { pageRoot = 1; pageFoot = pageCount; } else { pageRoot = currentPage - stepNum > 1 ? currentPage - stepNum : 1; pageFoot = pageRoot + stepageSize > pageCount ? pageCount : pageRoot + stepageSize; pageRoot = pageFoot - stepageSize < pageRoot ? pageFoot - stepageSize : pageRoot; } pagebar = GetDetailbar(stype, stepNum, pageRoot, pageFoot, pageCount, countNum, pageSize, currentPage, Http1, HttpM, HttpN, limitPage); return pagebar; } public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string HttpN) { return GetPageBar(mode, stype, stepNum, countNum, pageSize, currentPage, HttpN, HttpN, HttpN, 0); } public static string GetPageUrl(int chkPage, string Http1, string HttpM, string HttpN, int limitPage) { string Http = string.Empty; if (chkPage == 1) Http = Http1; else Http = (chkPage > limitPage || limitPage == 0) ? HttpN : HttpM; return Http.Replace("<#page#>", chkPage.ToString()); } }
View Code
最后的效果是,如下图
代码基本上写好了,希望对大家有用,一起学习,一起进步
源码下载:http://pan.baidu.com/share/link?shareid=2604334191&uk=2920032010
相关文章推荐
- 基于jQuery实现仿搜狐辩论投票动画代码(附源码下载)
- 基于Jquery实现仿百度百科右侧导航代码附源码下载
- 基于jQuery实现交互体验社会化分享代码附源码下载
- jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
- 基于Jquery实现仿百度百科右侧导航代码附源码下载
- java 二维码生成与解析代码实现,程序源码下载可用
- js框架jquery实现分页效果代码下载
- 基于jQuery实现仿搜狐辩论投票动画代码(附源码下载)
- 基于jQuery实现交互体验社会化分享代码附源码下载
- jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
- JQuery实现分页程序代码
- jQuery实现带右侧索引功能的通讯录示例【附源码下载】
- 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)
- 移动端+微信小程序实现,手机端滑动分页代码思路
- javascript实现五星评价代码(源码下载)
- jQuery实现可以控制图片旋转角度效果(附demo源码下载)
- jQuery插件FusionCharts实现的2D面积图效果示例【附demo源码下载】
- jquery 分页控件实现代码
- jQuery+vue.js实现的九宫格拼图游戏完整实例【附源码下载】