某页码显示的helper 少量调整,另附js版


Posted in Javascript onSeptember 12, 2010

如果你只想下载现成的用,可以到这个页面上去找。
许可证是“WTFPL”,也就是“Do What The Fuck You Want To Public License”。

源代码如下(因为有注释,就不另外说明了):
public static class PageNumExt 
{ 
/// <summary> 
/// 使用传入的委托计算并产生友好的页码。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
public static void PageNumView(this object o, 
long currentPage, PageNumAction actionPageNum, Action actionFolding, 
long maxSiblings = 2, long preventFolding = 1) 
{ 
o.PageNumView(currentPage, actionPageNum, actionPageNum, actionFolding, maxSiblings, preventFolding); 
} 
/// <summary> 
/// 使用传入的委托计算并产生友好的页码。当前页码将会被特别对待。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
public static void PageNumView(this object o, 
long currentPage, PageNumAction actionCurrent, 
PageNumAction actionPageNum, Action actionFolding, 
long maxSiblings = 2, long preventFolding = 1) 
{ 
o.PageNumView( 
currentPage, actionCurrent, 
1, long.MaxValue, 
actionPageNum, i => { }, 
maxSiblings, actionPageNum, 
preventFolding, actionFolding, 
maxSiblings, 0, 
actionPageNum, i => { } 
); 
} 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。当前页码将会被特别对待。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
public static void PageNumView(this object o, 
long currentPage, PageNumAction actionCurrent, 
long beginPage, long endPage, 
PageNumAction actionPageNum, Action actionFolding, 
long maxSiblings = 2, long preventFolding = 1) 
{ 
o.PageNumView(currentPage, actionCurrent, beginPage, endPage, actionPageNum, actionPageNum, actionPageNum, actionFolding, maxSiblings, preventFolding); 
} 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。当前页码、起始页码和终止页码都指定了专用的委托来处理。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionBegin">处理起始页码的方式</param> 
/// <param name="actionEnd">处理结束页码的方式</param> 
/// <param name="actionSebling">处理临近页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
public static void PageNumView(this object o, 
long currentPage, PageNumAction actionCurrent, 
long beginPage, long endPage, 
PageNumAction actionBegin, PageNumAction actionEnd, 
PageNumAction actionSebling, Action actionFolding, 
long maxSiblings = 2, long preventFolding = 1) 
{ 
o.PageNumView( 
currentPage, actionCurrent, 
beginPage, endPage, 
actionBegin, actionEnd, 
maxSiblings, actionSebling, 
preventFolding, actionFolding, 
maxSiblings, maxSiblings, 
actionSebling, actionSebling 
); 
} 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。每一种页码的具体处理方式都需要由调用方指派委托。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionBegin">处理起始页码的方式</param> 
/// <param name="actionEnd">处理结束页码的方式</param> 
/// <param name="currentSiblings">当前页码的临近页码数量</param> 
/// <param name="actionCurrentSibling">处理临近页码的方式</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="endOfBegin">起始页临近页码的数量</param> 
/// <param name="beginOfEnd">结束页临近页码的数量</param> 
/// <param name="actionBeginSibling">处理起始页临近页码的方式</param> 
/// <param name="actionEndSibling">处理结束页临近页码的方式</param> 
public static void PageNumView(this object o, 
long currentPage, PageNumAction actionCurrent, 
long beginPage, long endPage, 
PageNumAction actionBegin, PageNumAction actionEnd, 
long currentSiblings, PageNumAction actionCurrentSibling, 
long preventFolding, Action actionFolding, 
long endOfBegin, long beginOfEnd, 
PageNumAction actionBeginSibling, PageNumAction actionEndSibling 
) 
{ 
long i = beginPage; 
// 如果起始页小于当前页,就开始处理起始页 
if (beginPage < currentPage) 
#region 
{ 
actionBegin(beginPage); 
i++; 
endOfBegin += i; // 解决靠近起始页的页码之后 
var siblingBegin = currentPage - currentSiblings; // 当前页的临近页从何处开始 
var foldingStart = siblingBegin - preventFolding; // 页码折叠的底线 
if (endOfBegin > siblingBegin) 
endOfBegin = siblingBegin; // 保证当前页的临近页,牺牲起始页的临近页 
for (; i < endOfBegin; i++) 
actionBeginSibling(i); 
if (i < foldingStart) // 如果还没到达折叠底线,就马上开始折叠 
{ 
actionFolding(); 
i = foldingStart + 1; // 跳到折叠之后的页码 
} 
} 
#endregion 
// 处理当前页之前的临近页 
for (; i < currentPage; i++) 
actionCurrentSibling(i); 
// 处理当前页 
actionCurrent(currentPage); 
i = currentPage + 1; // 表示当前页已经处理完成。 
// 由于不能保证当前页和期望的起始页的关系,所以在此从当前页开始计算。 
var goal = i + currentSiblings; // 设定一个目标 
if (goal > endPage) // 目标不要超过结束页 
goal = endPage; 
// 处理当前页之后的临近页,直到到达目标页为止 
for (; i < goal; i++) 
actionCurrentSibling(i); 
// 如果结束页大于当前页,就开始处理结束页 
if (endPage > currentPage) 
#region 
{ 
beginOfEnd = endPage - beginOfEnd; // 计算出结束页的临近页从何处开始 
var foldingStart = beginOfEnd - preventFolding; 
if (i < foldingStart) // 没有触及折叠底线,马上开始折叠 
{ 
actionFolding(); 
i = beginOfEnd; 
} 
else // 全部当作当前页的临近页来处理,但保留结束页的临近页 
for (; i < beginOfEnd; i++) 
actionCurrentSibling(i); for (; i < endPage; i++) 
actionEndSibling(i); 
actionEnd(endPage); 
} 
#endregion 
} 
}

JavaScript版的源代码可以直接在前面提到的页面下载,不过这里也列出一下:
!function () { 
var g = this; 
var def_maxSiblings = 2; 
var def_preventFolding = 1; 
function pnView1( 
currentPage, actionPageNum, actionFolding, 
maxSiblings, preventFolding 
) { 
/// <summary> 
/// 使用传入的委托计算并产生友好的页码。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
pnView2(currentPage, actionPageNum, actionPageNum, actionFolding, maxSiblings || def_maxSiblings, preventFolding || def_preventFolding); 
} 
function pnView2( 
currentPage, actionCurrent, 
actionPageNum, actionFolding, 
maxSiblings, preventFolding 
) { 
/// <summary> 
/// 使用传入的委托计算并产生友好的页码。当前页码将会被特别对待。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
pnView( 
currentPage, actionCurrent, 
1, Number.POSITIVE_INFINITY, 
actionPageNum, null, 
maxSiblings || def_maxSiblings, actionPageNum, 
preventFolding || def_preventFolding, actionFolding, 
maxSiblings || def_maxSiblings, 0, 
actionPageNum, null 
); 
} 
function pnView3( 
currentPage, actionCurrent, 
beginPage, endPage, 
actionPageNum, actionFolding, 
maxSiblings, preventFolding 
) { 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。当前页码将会被特别对待。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionPageNum">处理页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
pnView4(currentPage, actionCurrent, beginPage, endPage, actionPageNum, actionPageNum, actionPageNum, actionFolding, maxSiblings || def_maxSiblings, preventFolding || def_preventFolding); 
} 
function pnView4( 
currentPage, actionCurrent, 
beginPage, endPage, 
actionBegin, actionEnd, 
actionSebling, actionFolding, 
maxSiblings, preventFolding 
) { 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。当前页码、起始页码和终止页码都指定了专用的委托来处理。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionBegin">处理起始页码的方式</param> 
/// <param name="actionEnd">处理结束页码的方式</param> 
/// <param name="actionSebling">处理临近页码的方式</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="maxSiblings">临近页码的数量</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
pnView( 
currentPage, actionCurrent, 
beginPage, endPage, 
actionBegin, actionEnd, 
maxSiblings || def_maxSiblings, actionSebling, 
preventFolding || def_preventFolding, actionFolding, 
maxSiblings || def_maxSiblings, maxSiblings || def_maxSiblings, 
actionSebling, actionSebling 
); 
} 
function pnView( 
currentPage, actionCurrent, 
beginPage, endPage, 
actionBegin, actionEnd, 
currentSiblings, actionCurrentSibling, 
preventFolding, actionFolding, 
endOfBegin, beginOfEnd, 
actionBeginSibling, actionEndSibling 
) { 
/// <summary> 
/// 根据传入的参数和委托来计算并产生友好的页码。每一种页码的具体处理方式都需要由调用方指派委托。 
/// </summary> 
/// <param name="o"></param> 
/// <param name="currentPage">当前页码</param> 
/// <param name="actionCurrent">处理当前页码的方式</param> 
/// <param name="beginPage">预设的起始页码</param> 
/// <param name="endPage">预设的结束页码</param> 
/// <param name="actionBegin">处理起始页码的方式</param> 
/// <param name="actionEnd">处理结束页码的方式</param> 
/// <param name="currentSiblings">当前页码的临近页码数量</param> 
/// <param name="actionCurrentSibling">处理临近页码的方式</param> 
/// <param name="preventFolding">阻止折叠页码的临界值,超过这个数目的页码将会被折叠</param> 
/// <param name="actionFolding">处理被折叠页码的方式</param> 
/// <param name="endOfBegin">起始页临近页码的数量</param> 
/// <param name="beginOfEnd">结束页临近页码的数量</param> 
/// <param name="actionBeginSibling">处理起始页临近页码的方式</param> 
/// <param name="actionEndSibling">处理结束页临近页码的方式</param> 
var i = beginPage; 
// 如果起始页小于当前页,就开始处理起始页 
if (beginPage < currentPage) { 
actionBegin && actionBegin(beginPage); 
i++; 
endOfBegin += i; // 解决靠近起始页的页码之后 
var siblingBegin = currentPage - currentSiblings; // 当前页的临近页从何处开始 
var foldingStart = siblingBegin - preventFolding; // 页码折叠的底线 
if (endOfBegin > siblingBegin) 
endOfBegin = siblingBegin; // 保证当前页的临近页,牺牲起始页的临近页 
for (; i < endOfBegin; i++) 
actionBeginSibling && actionBeginSibling(i); 
if (i < foldingStart) // 如果还没到达折叠底线,就马上开始折叠 
{ 
actionFolding && actionFolding(); 
i = foldingStart + 1; // 跳到折叠之后的页码 
} 
} 
// 处理当前页之前的临近页 
for (; i < currentPage; i++) 
actionCurrentSibling && actionCurrentSibling(i); 
// 处理当前页 
actionCurrent && actionCurrent(currentPage); 
i = currentPage + 1; // 表示当前页已经处理完成。 
// 由于不能保证当前页和期望的起始页的关系,所以在此从当前页开始计算。 
var goal = i + currentSiblings; // 设定一个目标 
if (goal > endPage) // 目标不要超过结束页 
goal = endPage; 
// 处理当前页之后的临近页,直到到达目标页为止 
for (; i < goal; i++) 
actionCurrentSibling && actionCurrentSibling(i); 
// 如果结束页大于当前页,就开始处理结束页 
if (endPage > currentPage) { 
beginOfEnd = endPage - beginOfEnd; // 计算出结束页的临近页从何处开始 
var foldingStart = beginOfEnd - preventFolding; 
if (i < foldingStart) // 没有触及折叠底线,马上开始折叠 
{ 
actionFolding && actionFolding(); 
i = beginOfEnd; 
} 
else // 全部当作当前页的临近页来处理,但保留结束页的临近页 
{ 
for (; i < beginOfEnd; i++) 
actionCurrentSibling && actionCurrentSibling(i); 
} for (; i < endPage; i++) 
actionEndSibling && actionEndSibling(i); 
actionEnd && actionEnd(endPage); 
} 
} 
g.pnView1 = pnView1; 
g.pnView2 = pnView2; 
g.pnView3 = pnView3; 
g.pnView4 = pnView4; 
g.pnView5 = pnView; 
g.pnView = pnView; 
} ();

/201009/yuanma/pnView_NanaView.rar
Javascript 相关文章推荐
一些常用的JavaScript函数(json)附详细说明
May 25 Javascript
jquery实现带二级菜单的导航示例
Apr 28 Javascript
window.location.href的用法(动态输出跳转)
Aug 09 Javascript
加随机数引入脚本不让浏览器读取缓存
Sep 04 Javascript
AngularJS进行性能调优的7个建议
Dec 28 Javascript
javascript简单比较日期大小的方法
Jan 05 Javascript
更高效的使用JQuery 这里总结了8个小技巧
Apr 13 Javascript
JS html时钟制作代码分享
Mar 03 Javascript
浅谈angularJS的$watch失效问题的解决方案
Aug 11 Javascript
微信小程序使用radio显示单选项功能【附源码下载】
Dec 11 Javascript
如何获取TypeScript的声明文件.d.ts
May 01 Javascript
详解为生产环境编译Angular2应用的方法
Dec 10 Javascript
网页中CDATA标记的说明
Sep 12 #Javascript
JavaScript小技巧 2.5 则
Sep 12 #Javascript
让JavaScript拥有类似Lambda表达式编程能力的方法
Sep 12 #Javascript
JQuery FlexiGrid的asp.net完美解决方案 dotNetFlexGrid-.Net原生的异步表格控件
Sep 12 #Javascript
Asp.net下使用Jquery Ajax传送和接收DataTable的代码
Sep 12 #Javascript
Asp.net下利用Jquery Ajax实现用户注册检测(验证用户名是否存)
Sep 12 #Javascript
jQuery EasyUI 的EasyLoader功能介绍
Sep 12 #Javascript
You might like
PHP中返回引用类型的方法
2015/04/03 PHP
php微信浏览器分享设置以及回调详解
2016/08/01 PHP
php的PDO事务处理机制实例分析
2017/02/16 PHP
thinkphp3.2.0 setInc方法 源码全面解析
2018/01/29 PHP
php多进程模拟并发事务产生的问题小结
2018/12/07 PHP
JavaScript 学习笔记 Black.Caffeine 09.11.28
2009/11/30 Javascript
JavaScript 通过模式匹配实现重载
2010/08/12 Javascript
Jquery实现兼容各大浏览器的Enter回车切换输入焦点的方法
2014/09/01 Javascript
原生JavaScript编写俄罗斯方块
2015/03/30 Javascript
Angularjs 滚动加载更多数据
2016/03/17 Javascript
Vue.js 2.0 和 React、Augular等其他前端框架大比拼
2016/10/08 Javascript
微信小程序 登陆流程详细介绍
2017/01/17 Javascript
详解微信小程序设置底部导航栏目方法
2017/06/29 Javascript
解决vue select当前value没有更新到vue对象属性的问题
2018/08/30 Javascript
详解关于element el-button使用$attrs的一个注意要点
2018/11/09 Javascript
Bootstrap4 gulp 配置详解
2019/01/06 Javascript
vue获取验证码倒计时组件
2019/08/26 Javascript
vue实现输入一位数字转汉字功能
2019/12/13 Javascript
element跨分页操作选择详解
2020/06/29 Javascript
JavaScript 中的六种循环方法
2021/01/06 Javascript
DES加密解密算法之python实现版(图文并茂)
2018/12/06 Python
Python两个字典键同值相加的几种方法
2019/03/05 Python
python中metaclass原理与用法详解
2019/06/25 Python
对python中不同模块(函数、类、变量)的调用详解
2019/07/16 Python
在python中用url_for构造URL的方法
2019/07/25 Python
python 调用pyautogui 实时获取鼠标的位置、移动鼠标的方法
2019/08/27 Python
python识别验证码图片实例详解
2020/02/17 Python
前端实现背景虚化但内容清晰且自适应 的实例代码
2019/08/01 HTML / CSS
Blank NYC官网:夹克、牛仔裤等
2020/12/16 全球购物
2014自主招生自荐信策略
2014/01/27 职场文书
商家认证委托书格式
2014/10/16 职场文书
停电调休通知
2015/04/16 职场文书
护士爱岗敬业心得体会
2016/01/25 职场文书
再次探讨go实现无限 buffer 的 channel方法
2021/06/13 Golang
「海贼王」112.9万粉丝纪念图标公布
2022/03/21 日漫
windows10声卡驱动怎么安装?win10声卡驱动安装操作步骤教程
2022/08/05 数码科技