某页码显示的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 相关文章推荐
常见JS效果之图片减速度滚动实现代码
Dec 08 Javascript
Jquery实现控件的隐藏和显示实例
Feb 08 Javascript
纯js实现仿QQ邮箱弹出确认框
Apr 29 Javascript
3kb jQuery代码搞定各种树形选择的实现方法
Jun 10 Javascript
JS模拟bootstrap下拉菜单效果实例
Jun 17 Javascript
EasyUI中在表单提交之前进行验证
Jul 19 Javascript
js cookie实现记住密码功能
Jan 17 Javascript
div中文字内容溢出常见的解决方法
Mar 16 Javascript
浅谈angularJs函数的使用方法(大小写转换,拷贝,扩充对象)
Oct 08 Javascript
基于Vue组件化的日期联动选择器功能的实现代码
Nov 30 Javascript
微信小程序五子棋游戏AI实现方法【附demo源码下载】
Feb 20 Javascript
通过实例了解JS执行上下文运行原理
Jun 17 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
Zend引擎的发展 [15]
2006/10/09 PHP
Ajax提交表单时验证码自动验证 php后端验证码检测
2016/07/20 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
js关闭父窗口时关闭子窗口
2013/04/01 Javascript
javascript中RegExp保留小数点后几位数的方法分享
2013/08/13 Javascript
from 表单提交返回值用post或者是get方法实现
2013/08/21 Javascript
JS获得选取checkbox整行数据的方法
2015/01/28 Javascript
JavaScript实现的浮动层框架用法实例分析
2015/10/10 Javascript
JavaScript阻止回车提交表单的方法
2015/12/30 Javascript
JavaScript tab选项卡插件实例代码
2016/02/23 Javascript
angular ngClick阻止冒泡使用默认行为的方法
2016/11/03 Javascript
Bootstrap Scrollspy源码学习
2017/03/02 Javascript
node.js爬虫爬取拉勾网职位信息
2017/03/14 Javascript
javascript trie前缀树的示例
2018/01/29 Javascript
angularjs结合html5实现拖拽功能
2018/06/25 Javascript
JS实现字符串翻转的方法分析
2018/08/31 Javascript
vue+axios实现文件下载及vue中使用axios的实例
2018/09/21 Javascript
[04:02]2014DOTA2国际邀请赛 BBC每日综述中国战队将再度登顶
2014/07/21 DOTA
python批量导出导入MySQL用户的方法
2013/11/15 Python
Python threading多线程编程实例
2014/09/18 Python
python冒泡排序简单实现方法
2015/07/09 Python
Python时间的精准正则匹配方法分析
2017/08/17 Python
Tensorflow 自带可视化Tensorboard使用方法(附项目代码)
2018/02/10 Python
教你利用Python玩转histogram直方图的五种方法
2018/07/30 Python
Python插入Elasticsearch操作方法解析
2020/01/19 Python
Artist Guitars新西兰:乐器在线商店
2017/09/17 全球购物
文秘专业大学生求职信
2013/11/10 职场文书
四风存在的原因分析
2014/02/11 职场文书
2014年秋季开学演讲稿
2014/05/24 职场文书
家庭贫困证明
2014/09/23 职场文书
我们的节日中秋节活动总结
2015/03/23 职场文书
小学校园广播稿
2015/08/18 职场文书
2016年度创先争优活动总结
2016/04/05 职场文书
2019最新婚庆对联集锦!
2019/07/10 职场文书
创业计划之特色精品店
2019/08/12 职场文书
Zabbix对Kafka topic积压数据监控的解决方案
2022/07/07 Servers