/*
Author: Calos
Description: patv2 pager
!import: this pager goes with the time, we just temporarily stay, what a sad fact!
*/
(function ($) {
$.fn.patpager = function (options) {
options = options || {
turnPageTriggered: function (indexer) {
indexer = indexer || { pageIndex: 1, pageSize: 10 };
}, pageIndex: 1, pageSize: 10, pageCount: 10
};
var pagerStatus = { pageIndex: options.pageIndex || 1, pageSize: options.pageSize || 10 };
var $this = $(this);
$this.children().remove();
var timestamp = new Date().getTime();
var caching = {};
var fetchIndexer = function (indexerTo, transform) {
if (options.turnPageTriggered) {
transform();
options.turnPageTriggered(indexerTo);
}
}
var components = {
Turntopage: '<label>Turn to page</label>',
pageIndex: function (num) { return '<input type="text" class="pageTo" value=' + num + '>'; },
previousPage: '<a class="prev"><<</a>',
curStatus: function (pageIndex, totalPages) { return 'page <span class="cur">' + pageIndex + '</span> of <span class="totalPages">' + totalPages + '</span>'; },
nextPage: '<a class="next">>></a>'
};
var methods = {
createPager: function (pageIndex, totalPage) {
var html = '<div class=' + timestamp + ' >' + components.Turntopage + components.pageIndex(pageIndex) + components.previousPage + components.curStatus(pageIndex, totalPage) + components.nextPage + '</div>';
$this.html(html);
},
refreshCache: function () {
caching = {
pageTo: $this.find('.pageTo'),
prev: $this.find('.prev'),
pageIndex: $this.find('.cur'),
totalPages: $this.find('.totalPages'),
next: $this.find('.next')
}
$(".prev,.next").css('cursor', 'pointer');
},
initPager: function (option) {
methods.createPager(option.pageIndex, option.pageSize);
this.refreshCache();
},
pageIndexChanged: function (pager, sendInitTableRequest) {
pager = pager || { pageTo: 1, pageSize: 10 };
var totalPage = sendInitTableRequest(pager);
caching.pageIndex.text(pager.pageTo);
},
setCurrentPage: function (pageTo) { caching.pageIndex.text(pageTo >= 1 ? pageTo : 1) },
getCurrentPage: function () { return parseInt(caching.pageIndex.text()); },
ensureFirstPage: function () {
return this.getCurrentPage() === 1;
},
ensureLastPage: function () {
return this.getCurrentPage() === options.pageCount;
},
turnToPreviousPage: function () {
pagerStatus.pageIndex = methods.getCurrentPage() - 1;
fetchIndexer(pagerStatus, function () {
methods.setCurrentPage(pagerStatus.pageIndex);
});
},
turnToNextpage: function () {
pagerStatus.pageIndex = methods.getCurrentPage() + 1;
fetchIndexer(pagerStatus, function () {
methods.setCurrentPage(pagerStatus.pageIndex);
});
},
turnTopage: function (index) {
pagerStatus.pageIndex = index;
fetchIndexer(pagerStatus, function () {
methods.setCurrentPage(pagerStatus.pageIndex);
});
},
ensureValidPageIndex: function () {
var i = caching.pageTo.val();
var c = parseInt(caching.totalPages.text());
if (i <= 0) { caching.pageTo.val(1); caching.pageIndex.text(1); return true; }
if (i >= c) { caching.pageTo.val(c); caching.pageIndex.text(c); return true; }
return /\d/gim.test(i) && i > 0 && i < parseInt(caching.totalPages.text());
}
};
var behaviors = {
prevClick: function () {
methods.turnToPreviousPage();
},
nextClick: function () {
methods.turnToNextpage();
},
curChange: function () {
}
}; var getFrame = function (selector) {
return '.' + timestamp + ' ' + selector;
} $this.on('click', getFrame('.prev'), function (e) {
if (!methods.ensureFirstPage())
behaviors.prevClick();
});
$this.on('click', getFrame('.next'), function (e) {
if (!methods.ensureLastPage())
behaviors.nextClick();
});
$this.on('keydown blur', '.pageTo', function (e) {
var eType = $.inArray(e.type, ['focusout', 'keydown']);
if ((eType === 1 && e.keyCode === 13) || eType === 0) {
if (methods.ensureValidPageIndex()) {
var index = caching.pageTo.val();
methods.turnTopage(index);
}
}
}); methods.initPager(options);
return this;
}
})(jQuery);


 效果:

写了个pager, 可供参考的更多相关文章

  1. Unity上一页下一页切换功能实现源码(仅供参考)

    在做项目时我们有时需要实现切换上一页下一页图片,切换上一首下一首歌曲等等类似的功能.这里写了个简单的实现源码(仅供参考),要是有更好的方法欢迎提出来,共同进步~ 以切换上一页下一页图片为例: usin ...

  2. mysql 千万级数据查询效率实践,分析 mysql查询优化实践--本文只做了一部分,仅供参考

    数据量, 1300万的表加上112万的表 注意: 本文只做了部分优化,并不全面,仅供参考, 欢迎指点.   请移步tim查看,因为写的时候在tim写的,粘贴过来截图有问题,就直接上链接了. https ...

  3. 【WPF】SnapsToDevicePixels与UseLayoutRounding二者到底有什么区别?供参考

    原文:[WPF]SnapsToDevicePixels与UseLayoutRounding二者到底有什么区别?供参考 MSDN上解释了一大堆,二者对比来看,并不能发现什么明显的区别,微软爸爸也不知道多 ...

  4. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  5. EF封装类 增加版,增加从缓存中查找数据方法,供参考!

    EF封装类 增加版,增加从缓存中查找数据方法,供参考! 这个类是抽象类,我这里增加了需要子类验证的方法ValidateEntity,方便扩展,若想直接使用该类,可以将该类更改成静态类,里面所有的方法都 ...

  6. EF封装类,供参考!

    以下是我对EF DB FIRST 生成的ObjectContext类进行封装,代码如下,供参考学习: using System; using System.Collections.Generic; u ...

  7. 为mutable类型的容器(array,set等)添加kvo,有点麻烦,供参考和了解下吧

    http://blog.csdn.net/caryaliu/article/details/49284185 需要在被观察的属性所在的类里面实现一些方法,对开发者不友好,一般不建议使用,这里mark一 ...

  8. configure错误列表供参考

    另外附一些常见的configure错误列表供参考: configure: error: No curses/termcap library found网上有的说法是:--with-named-curs ...

  9. Ubuntu 12.04 分区方案(仅供参考)

    Ubuntu 12.04 分区方案(仅供参考)   总空间大小:50G 目录 建议大小 实际大小 格式 描述 / 10G~20G 10G ext4 根目录 swap <2048M 1G swap ...

随机推荐

  1. = splice

    <script> function wf(w){ console.log(w); } var wa = [3,66,7]; var wb = wa; wa.splice(1,1); wf( ...

  2. Finally 与 return

    网上有很多人探讨Java中异常捕获机制try...catch...finally块中的finally语句是不是一定会被执行?很多人都说不是,当然他们的回答是正确的,经过我试验,至少有两种情况下fina ...

  3. 编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时会产生Additional information: 阅读器关闭时尝试调用 Read 无效问题,解决方法与解释

    在自学杨中科老师的视频教学时,拓展编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时 会产生Additional information: 阅读器关闭时尝试调用 ...

  4. HTTP 协议的历史演变和设计思路

    HTTP 协议是互联网的基础协议,也是网页开发的必备知识,最新版本 HTTP/2 更是让它成为技术热点. 本文介绍 HTTP 协议的历史演变和设计思路. 一.HTTP/0.9 HTTP 是基于 TCP ...

  5. sublime text2 操作及插件

    sublime text2 1. 文件快速导航: 这是sublime上面很好用的功能之一,ctrl+p可以调出窗口,菜单上的解释是gotoanythings ,确实如其所言,调出窗口后,直接输入关键字 ...

  6. Java学习-018-EXCEL 文件写入实例源代码

    众所周知,EXCEL 也是软件测试开发过程中,常用的数据文件导入导出时的类型文件之一,此文主要讲述如何通过 EXCEL 文件中 Sheet 的索引(index)或者 Sheet 名称获取文件中对应 S ...

  7. Selenium2学习-003-WebUI自动化实战实例-001-百度搜索

    此文主要通过百度搜索功能,进行 Selenium2 的实战实例讲解,文中所附源代码于 2015-01-16 02:01 亲测通过,敬请亲们阅览.希望能对初学 Selenium2 UI 自动化测试编程的 ...

  8. office-002-onenote、word、outlook取消首字母大小写图文详解

    此文主要讲述如何取消微软办公软件 onenote.work.outlook 中首字母大写等的自动更正项,其他 office 办公软件相关设置的操作,可参考此文进行相应的设置.希望能对亲有所帮助,若有错 ...

  9. C++经典编程题#4:单词翻转

    总时间限制:  1000ms  内存限制:  65536kB 描述 输入一个句子(一行),将句子中的每一个单词翻转后输出. 输入 只有一行,为一个字符串,不超过500个字符.单词之间以空格隔开. 输出 ...

  10. linux i2c tools

    最近要操作eeprom,所以了解一下i2c-tool的使用方法,记录于此. 参考链接: http://www.myir-tech.com/bbs/thread-7567-1-1.html http:/ ...