(function($) {
$.fn.pager = function(options) {
var opts = $.extend({}, $.fn.pager.defaults, options);
return this.each(function() {
// empty out the destination element and then render out the pager with the supplied options
$(this).empty().append(renderpager(parseInt(options.pagenumber), parseInt(options.pagecount), options.buttonClickCallback));
});
};
// render and return the pager with the supplied options
function renderpager(pagenumber, pagecount, buttonClickCallback) {
// setup $pager to hold render
var $pager = $('<ul class="pages"></ul>');
// add in the previous and next buttons
$pager.append(renderButton('首页', pagenumber, pagecount, buttonClickCallback)).append(renderButton('上一页', pagenumber, pagecount, buttonClickCallback));
// pager currently only handles 10 viewable pages ( could be easily parameterized, maybe in next version ) so handle edge cases
var startPoint = 1;
var endPoint = 9;
if (pagenumber > 4) {
startPoint = pagenumber - 4;
endPoint = pagenumber + 4;
}
if (endPoint > pagecount) {
startPoint = pagecount - 8;
endPoint = pagecount;
}
if (startPoint < 1) {
startPoint = 1;
}
// loop thru visible pages and render buttons
for (var page = startPoint; page <= endPoint; page++) {
var currentButton = $('<li class="page-number">' + (page) + '</li>');
page == pagenumber ? currentButton.addClass('pgCurrent') : currentButton.click(function() { buttonClickCallback(this.firstChild.data); });
currentButton.appendTo($pager);
}
// render in the next and last buttons before returning the whole rendered control back.
$pager.append(renderButton('下一页', pagenumber, pagecount, buttonClickCallback)).append(renderButton('末页', pagenumber, pagecount, buttonClickCallback));
return $pager;
}
// renders and returns a 'specialized' button, ie 'next', 'previous' etc. rather than a page number button
function renderButton(buttonLabel, pagenumber, pagecount, buttonClickCallback) {
var $Button = $('<li class="pgNext">' + buttonLabel + '</li>');
var destPage = 1;
// work out destination page for required button type
switch (buttonLabel) {
case "首页":
destPage = 1;
break;
case "上一页":
destPage = pagenumber - 1;
break;
case "下一页":
destPage = pagenumber + 1;
break;
case "末页":
destPage = pagecount;
break;
}
// disable and 'grey' out buttons if not needed.
if (buttonLabel == "首页" || buttonLabel == "上一页") {
pagenumber <= 1 ? $Button.addClass('pgEmpty') : $Button.click(function() { buttonClickCallback(destPage); });
}
else {
pagenumber >= pagecount ? $Button.addClass('pgEmpty') : $Button.click(function() { buttonClickCallback(destPage); });
}
return $Button;
}
// pager defaults. hardly worth bothering with in this case but used as placeholder for expansion in the next version
$.fn.pager.defaults = {
pagenumber: 1,
pagecount: 1
};
})(jQuery);
var $pager = $("#pager");
$pager.pager({
pagenumber: ${pager.pageNumber},
pagecount: ${pager.pageCount},
buttonClickCallback: $.gotoPage
});
分享到:
相关推荐
由samwilson开发的AddNewPage插件,版本为2015-11-02-17-g9856122,是DokuWiki的一个实用工具,它提供了一个直观的按钮,允许用户快速创建新的页面。这个功能对于频繁创建新页面的用户非常有用,简化了他们的操作...
本资源为谷歌浏览器的截图插件(Capture Page插件),格式为CRX,可直接安装,欢迎大家下载!
接着,我们来看`src`目录,这通常包含了Page插件的源码。在源码中,开发者会找到实现分页功能的核心逻辑,包括计算总页数、生成分页链接、处理点击事件等功能。源码可能由多个JavaScript文件组成,例如`page.js`可能...
3. **易用性**:bPage插件的API设计简洁,开发者可以快速上手,且有丰富的文档和示例供参考。 ### 二、依赖与安装 bPage插件依赖于Bootstrap和jQuery,因此在使用前需要确保项目中已引入这两者。可以通过以下方式...
在"page_jquery"这个文件中,我们可以预期包含的是使用jQuery实现的zxf_page插件代码。 在实际使用zxf_page时,开发者需要首先引入jQuery库,然后引入zxf_page插件的JavaScript和CSS文件。接着,需要在HTML中设置...
为了提供更好的用户体验,开发人员经常使用“loading插件”来创建动态的加载指示器,即loading遮罩效果。这些插件可以有效地告诉用户系统正在进行后台操作,并且内容即将呈现,从而减少用户的焦虑感。 "jQuery-...
费时费力,到最后,你还不一定能修改好,如果你还这个问题而烦恼,那么,你可以试下这个插件下载Different Post Per Page插件,它可以让你自定义页面上显示的日志数量。 Different Post Per Page插件安装: 1.下载...
R-page插件就是这一过程中的得力助手,它能模拟不同类型的移动设备,如智能手机和平板电脑,帮助开发者检测并修正可能出现的显示问题。 在使用Google Chrome R-page插件时,开发者首先需要安装该插件到他们的谷歌...
下载Page Flip Image Gallery插件,将压缩包解压后,把文件夹上传到wp-content/plugins/目录下,登录WordPress管理后台,点击“Plugins”找到上传的插件,激活该插件,插件激活后,在后台的左侧栏的最下方...
OnePageNav是一款流行的JavaScript插件,专为单页面网站设计,用于实现响应式的滚动导航功能。这个插件能够轻松地将导航菜单项与页面上的各个部分进行同步,当用户滚动页面时,相应的导航链接会自动激活,提供优秀的...
### 一、jQuery Page 插件简介 jQuery Page 是基于JavaScript库jQuery开发的一款轻量级分页组件。它通过CSS样式和JavaScript脚本实现了美观的分页效果,使得用户在浏览大量数据时能够轻松跳转,提升用户体验。该...
这些工具通常作为浏览器扩展或插件存在,以提供即时的网页翻译服务。 首先,`firefox_manifest.json` 和 `manifest.json` 是两种常见的Web应用程序清单文件。`manifest.json` 文件是Chrome和Firefox等浏览器扩展的...
Page Ruler(Chrome页面区域测量插件)是一款chrome页面区域测量插件工具,主要能对网页中板块的宽度、高度的像素大小进行测量或设定好固定大小来框选需要的区域测试其像素大小,简单而实用,在安装了这款插件后,使用...
适用于统计文章/页面点击及总浏览量的插件,比较早了 优化内容:统计次数超过1000次后,单位转化为千次,...在后台——控制——插件中启用PageViews插件,如果要设置起始浏览器,就点击插件后台的【设置】按钮进行设置
PageOffice是一款专为Web应用程序设计的在线编辑Office文档的插件。它允许用户在网页浏览器中直接打开、编辑、预览、打印Word、Excel和PowerPoint等Microsoft Office格式的文件,无需安装任何额外的客户端软件。这个...
**jQuery One Page Nav 插件详解** 在网页设计中,单页布局正逐渐成为一种流行趋势,它将所有内容集中在一个页面上,提供简洁、直观的用户体验。为了优化这种布局的导航,`jQuery One Page Nav` 插件应运而生。这个...
大家第一反应想到的肯定是WP-PageNavi插件,这款插件在WordPress分页方面可以说是久负盛名,不过,感觉它的样式太过单一了,页码排列的顺序也有点怪怪的,O(∩_∩)O~,今天就介绍一款样式较多的分页插件WP Page ...
"Hack This Page-crx插件"是一款针对网页编辑的浏览器扩展程序,主要服务于那些希望对网页内容进行编辑或实验性修改的用户。这款插件能够让用户像操作文本文档一样直接编辑网页,提供了便捷的在线网页修改功能。下面...
PageOffice for Java是一款非常优秀的专业的集成微软OFFICE功能的Java控件平台,能够帮助Web开发人员轻松实现在网页中嵌入运行微软Office的特殊功能
Page.js 是一个专为JavaScript设计的轻量级分页插件,它使得在Web应用中实现动态数据渲染分页变得极其简单。下面将详细介绍Page.js分页插件的核心特点、使用方法以及常见应用场景。 一、Page.js概述 Page.js 是一...