(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中设置...
Page Assist插件是专为Google Chrome浏览器设计的一款辅助工具,其主要作用在于通过特定的扩展功能增强用户的浏览体验。使用该插件之前,用户需要在Chrome浏览器中开启开发者模式,然后将包含插件功能文件的压缩包...
ollama的chrome浏览器插件——Page Assist,就是一个专注于提供便捷Web界面的应用。这个插件通过一系列精心设计的文件共同作用,赋予用户更直观、更高效的网页交互能力。 首先,sidepanel.html文件是整个插件的侧...
Page Assist作为一款谷歌插件,其核心特性在于内置了本地AI模型,这一创新的设计使得它能够提供更为智能化的Web UI(用户界面)辅助功能。 首先,我们可以从标题“Page Assist - 本地 AI 模型的 Web UI 谷歌插件”...
为了提供更好的用户体验,开发人员经常使用“loading插件”来创建动态的加载指示器,即loading遮罩效果。这些插件可以有效地告诉用户系统正在进行后台操作,并且内容即将呈现,从而减少用户的焦虑感。 "jQuery-...
费时费力,到最后,你还不一定能修改好,如果你还这个问题而烦恼,那么,你可以试下这个插件下载Different Post Per Page插件,它可以让你自定义页面上显示的日志数量。 Different Post Per Page插件安装: 1.下载...
R-page插件就是这一过程中的得力助手,它能模拟不同类型的移动设备,如智能手机和平板电脑,帮助开发者检测并修正可能出现的显示问题。 在使用Google Chrome R-page插件时,开发者首先需要安装该插件到他们的谷歌...
Firefox浏览器page_assist-1.4.4离线插件是一种专门为Firefox浏览器设计的插件,它的主要功能是提供强大的网页辅助功能。该插件的版本号为1.4.4,这意味着它已经经过多次更新和优化,具有较高的稳定性和兼容性。 该...
标题中提到的“浏览器插件Page Assist-1.4.5”指的是一个特定版本号的网页浏览器扩展程序。这种插件通常用于增强或修改浏览器的标准功能,为用户提供额外的便利性或特殊功能。从标题中我们可以推断,Page Assist插件...
下载Page Flip Image Gallery插件,将压缩包解压后,把文件夹上传到wp-content/plugins/目录下,登录WordPress管理后台,点击“Plugins”找到上传的插件,激活该插件,插件激活后,在后台的左侧栏的最下方...
针对这一需求,page-assist谷歌浏览器插件应运而生,它是一个专门设计来调用AI大模型的工具。该插件能够在用户的谷歌浏览器中运行,通过与AI大模型的对接,为用户提供智能化的网页浏览体验。例如,它可以进行智能...
OnePageNav是一款流行的JavaScript插件,专为单页面网站设计,用于实现响应式的滚动导航功能。这个插件能够轻松地将导航菜单项与页面上的各个部分进行同步,当用户滚动页面时,相应的导航链接会自动激活,提供优秀的...
Page Assist Chrome浏览器插件 crx格式 使用Page Assist + Ollama + DeepSeek 实现 DeepSeek 离线部署后的联网搜索 Page Assist 是一款开源的浏览器扩展程序 用户可在插件中开启联网按钮,借助本地 AI 模型进行...
适用于统计文章/页面点击及总浏览量的插件,比较早了 优化内容:统计次数超过1000次后,单位转化为千次,...在后台——控制——插件中启用PageViews插件,如果要设置起始浏览器,就点击插件后台的【设置】按钮进行设置
### 一、jQuery Page 插件简介 jQuery Page 是基于JavaScript库jQuery开发的一款轻量级分页组件。它通过CSS样式和JavaScript脚本实现了美观的分页效果,使得用户在浏览大量数据时能够轻松跳转,提升用户体验。该...
这些工具通常作为浏览器扩展或插件存在,以提供即时的网页翻译服务。 首先,`firefox_manifest.json` 和 `manifest.json` 是两种常见的Web应用程序清单文件。`manifest.json` 文件是Chrome和Firefox等浏览器扩展的...