积跬步,聚小流------用smartpaginator来做分页

2023-05-16

|  网络上的实例


(jquery smarypaginator 例图)

如果说是从“百度”上搜索过“jquery分页插件”的朋友,相信对上面的图片不会陌生,几乎所有介绍“jquery分页插件”的文章中都会出现它的影子,当然可能有下载使用过的朋友也发现了,它存在着几个致命的问题:

1、适用于小数据量的访问;(其实这点算不得缺陷,只是适用环境不同而已);

2、页面跳转中跳转页码的输入,小键盘不能录入;

3、参数length,存在一个限制,length如果大于totalrecords、recordsperpage时,是不显示上一页、下一页、首页和尾页的;

但是,瑕不掩瑜,正所谓根本不存在什么完美,合适的才是最好的,它的简单灵活让我在最初就选择了它,并进行修改整理后,完成个人想要的效果。

网上的具体事例可以点击此处:demo-分页插件smartpaginator

|  插件使用说明

首先来看下原始插件的基本方法:

1、引入相应的js和css文件;

<script src="jquery-1.4.4.min.js" type="text/javascript"></script>
<script src="smartpaginator.js" type="text/javascript"></script>
<link href="smartpaginator.css" rel="stylesheet" type="text/css" />

2、写一个div来模拟显示数据,写一个div来放置分页部分;

<div id="pagination_testpart">
</div>
<div id="page_part">
</div>

3、初始化插件(一般我习惯放到另一个单独的js文件中)

$(document).ready(function() {
     $('#page_part').smartpaginator({ 
          totalrecords: total, 
          recordsperpage: items_per_page, 
          next: '下一页', 
          prev: '上一页', 
          first: '首页', 
          last: '末页', 
          go: '前往',
          theme: 'red', 
          initval: current_page,
          onchange: onPageChange
      });
});

function onPageChange(newPageValue) {
          current_page = newPageValue; //根据新的页码做一些改变,比如说页面更新操作
          getImageList(newPageValue);
}

(参考文章:上品物语-博客园)

|  参数介绍

可以参考如下图片:


|  问题解决

对于前面提到的问题,对于后两个进行解决,至于第一个问题,还是之前所说的,只是使用环境不同而已,将我在实例中修改后的贴上来看下:

//重新封装分页插件应用的相应js

$(function(){//第一次加载界面是默认显示第一页
	ajax_getData(1);
});

function ajax_getData(n){ //通过ajax获取json数据
		$.ajax({
			type: "GET",
			url: "data_test.json",//后台给予的数据,可以传递参数来设定
			dataType: "json",
			success: function(data){
				$("#pagination_testpart").html("");
				var a="";
				var perPage=data.length>10?10:data.length;//定义每页显示条数
				var startPage=perPage*(n-1)+1;//定义初始条数
				for(var i=0;i<perPage&&i+startPage<data.length;i++){
					a=a+"<p>"+data[i+startPage].code+"</p>";							        }
				$("#pagination_testpart").html(a);
				tt(data.length,perPage,3,n);	
				},
				error: function(XMLHttpReqst,textStatus,errorThrown){
					alert(errorThrown); 
				}
		});	
}
function tt($totalrecords,$recordsperpage,$length,$initval){
	 $('#page_part').smartpaginator({
				 totalrecords: $totalrecords,
				 recordsperpage: $recordsperpage, 
				 length: $length, 
				 next: '下一页', 
				 prev: '上一页', 
				 first: '首页', 
				 last: '尾页',  
				 theme: 'red', 
				 initval: $initval,
				 controlsalways: true, 
				 onchange: function (newPage) {
					ajax_getData(newPage);
				 }
	});
}

1、修改“小键盘不能录入”的问题;

通过查看封装的js,可以发现问题出现的原因,大约在45行左右,可以发现如下判断,只是判断了主键盘上的数字按键,小键盘肯定不会进行响应。

 var inputPage = $('<input/>').attr('type', 'text').keydown(function (e) {
                    if (isTextSelected(inputPage)) inputPage.val('');
                    if (e.which >= 48 && e.which < 58) {
                        var value = parseInt(inputPage.val() + (e.which - 48));
                        if (!(value > 0 && value <= totalpages)) e.preventDefault();
                    } else if (!(e.which == 8 || e.which == 46)) e.preventDefault();
});/*没有判断加小键盘*/
找到症结所在,我们就可以来进行修复:

var inputPage = $('<input/>').attr('type', 'text').keyup(function (e) {
                    if (isTextSelected(inputPage)) inputPage.val(''){
					var value = inputPage.val();
					value=value.replace(/\D/,'');
					inputPage.val(value);
					value=parseInt(value);}
                     if (value > totalpages)<span style="font-family: Arial, Helvetica, sans-serif;">{</span>
				inputPage.val(totalpages);
				e.preventDefault();}
                 });

2、length参数问题;

大约在代码270行左右,会发现这样一句代码:

  if (totalpages > settings.length) {}

而else中对则对所有按钮添加了class:disabled;

既然症结在此,我们就可以将if条件判断去掉,同时将else中内容删掉即可。



本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

积跬步,聚小流------用smartpaginator来做分页 的相关文章

  • 最新Spire.pdf Spire.Doc Spire.Xls等无水印使用

    Aspose与Spire功能都很强大 xff0c 为什么要选择Spire xff0c Spire支持WPF组件 xff0c Aspose默认没有 新建 net6控制台程序 xff0c 用NuGet包添加Spire PDF引用 添加代码 us
  • 使用Pyinstaller发布带界面的程序(解决找不到文件问题)

    Pyinstaller Pyinstaller可以用来打包python代码 xff0c 生成可执行文件 xff08 主流平台都可以 xff09 xff0c 介绍就不说了 xff0c 可以百度或者去官网看看 xff1a https www p
  • 动态分配内存——new/delete

    动态分配内存 1 使用new分配内存2 使用delete释放内存3 例子 xff1a 数组编译时分配内存和运行时分配内存4 动态数组补充 xff1a 程序的内存分配 1 使用new分配内存 使用格式 xff1a span class tok
  • Spring学习(一) Spring环境配置

    工具原料 xff1a JDK Eclipse IDEA 开始学Spring xff0c 应该已经安好java环境了 xff0c 这里我就不赘述了 xff0c 直接开始开始下一步的教程 配置spring环境需要导入spring相关的jar包
  • vue-lottie动画效果(进阶篇)

    vue lottie动画效果 以下是个人见解部分 个人见解 xff1a 优点 xff1a 简单高效 xff0c 动画文件小 xff0c 丝滑流畅 xff0c 动画可控性强 缺点 xff1a 依赖包非常重 xff0c 对动画要求不高的项目不太
  • Ubuntu18.04设置开机自启动自己的程序、脚本

    Ubuntu18 04设置开机自启动自己的程序 脚本 本文使用的机器是win10 43 Ubuntu18 04双系统 xff0c 虚拟机上的Ubuntu18 04操作一样 xff0c 均可参考此文 参考链接 xff0c 言简意赅 xff0c
  • 【Qt】【QDebug】【日志】实用的Qt日志打印-打印时间-线程-数据等信息

    Qt QDebug 日志 实用的Qt日志打印 打印时间 线程 数据等信息 在开发audio和video相关软件时 xff0c 收发速率很关键 xff0c 我们需要打印时间和线程等相关信息等日志 include lt QDebug gt 获取
  • DNS(域名解析协议)详解

    DNS协议 我们之前已经了解过ARP协议 如果说ARP协议是用来将IP地址转换为MAC地址 xff0c 那么DNS协议则是用来将域名转换为IP地址 xff08 也可以将IP地址转换为相应的域名地址 xff09 我们都知道 xff0c TCP
  • Mybatis之使用注解开发CRUD

    上一篇演示了如何使用XML来操作Mybatis实现CRUD xff0c 但是大量的XML配置文件的编写是非常烦人的 因此 Mybatis也提供了基于注解的配置方式 xff0c 下面我们来演示一下使用接口加注解来实现CRUD的的例子 首先是创
  • 查看windows服务器的I/O的3种方法

    http blog chinaunix net uid 20344928 id 5597137 html 碎碎念 xff1a 感觉第二种简单 windows查看I O的方法有3种 xff1a 1 任务管理器 打开任务管理器 xff0c 点击
  • 【Tensorflow】辅助工具篇——scikit-image介绍

    很多时候我们跑deep learning算法的难点不在于搭建网络 xff0c 而是数据获取与处理 xff0c 当你看到大量的数据却无从下手时该是怎样的心情 xff01 这几篇我将为大家介绍目前很多paper代码复现中比较流行的辅助工具 首先
  • 一劳永逸,wsl2出现“参考的对象类型不支持尝试的操作”的解决办法

    wsl在使用是会出现 参考的对象类型不支持尝试的操作 的故障导致无法使用 出现上述问题原因是使用代理软件 xff0c 或游戏加速服务 xff0c winsock出现问题 可以通过注册表的方式 xff0c 排除从winsock中排除wsl即可
  • Python中的路径获取方法总结

    遍历文件夹下文件 xff1a os walk dir path def getFlist path for root dirs files in os walk file dir print 39 root dir 39 root 当前路径
  • Android Studio设置了断点却无法进入断点调试(多进程调试)

    有的时候在Android Studio中明明设置了断点 xff0c 也确认了代码会走到断点处 xff0c 但是执行Debug后 xff0c 断点处会显示打钩 xff0c 却不能但不调试 xff0c 好像代码已经执行过去了 这种问题大概率就是
  • mysql16

    常见面试题 MySQL 中有哪些存储引擎 xff1f InnoDB 存储引擎 InnoDB 是 MySQL 的默认事务型引擎 xff0c 也是最重要 使用最广泛的存储引擎 它被设计用来处理大量的短期 short lived 事务 xff0c
  • CSDN 博客备份工具

    前言 核心 登录模块 备份模块 博文扫描模块 演示 如何使用 效果 总结 前言 近段时间以来 听群友博友都在谈论着一件事 CSDN博客怎么没有备份功能啊 这其实也在一定程度上表征着大家对于文章这种知识性产品的重视度越来越高 也对于数据的安全
  • 如何在 Linux 中查找一个文件

    导读对于新手而言 xff0c 在 Linux 中使用命令行可能会非常不方便 没有图形界面 xff0c 很难在不同文件夹间浏览 xff0c 找到需要的文件 本篇教程中 xff0c 我会展示如何在 Linux 中查找特定的文件 第一步要做的是通
  • [Android 调试] 解决linux系统不识别设备、手机问题方法

    最近在开发过程中linux不识别开发板设备 手机 xff0c 看了下dev guide xff0c 现在把方法提供给大家 1 If you 39 re developing on Ubuntu Linux you need to add a
  • spring开发篇二:@RequestParam和@RequestBody与前端Get和Post请求传参详解附中文乱码解决方法

    1 先入为主 xff1a 1 1 在spring的controller中注解写法规则 xff1a xff08 a xff09 同一个请求中 xff0c 只能有一个 64 RequestBody xff1b xff08 b xff09 同一个
  • ICMP协议详解

    ICMP协议详解 ICMP协议是一个网络层协议 一个新搭建好的网络 xff0c 往往需要先进行一个简单的测试 xff0c 来验证网络是否畅通 xff1b 但是IP协议并不提供可靠传输 如果丢包了 xff0c IP协议并不能通知传输层是否丢包

随机推荐

  • nginx系列之健康检查模块配置安装(nginx_upstream_check_module)

    nginx安装步骤 xff0c 不详述 xff0c 请查看nginx系列篇 xff0c 安装 nginx安装教程 1 下载nginx upstream check module模块 nginx upstream check module m
  • linux系统维护篇:centos6.5 yum无法安装YumRepo Error: All mirror URLs are not using ftp, http[s] or file

    在使用yum安装软件的时候突然提示错误 xff1a root 64 dukeServer softwares yum install tcp Loaded plugins fastestmirror security Setting up
  • linux系统维护篇:网络流量查看及带宽测试

    前提准备 xff1a 由于即将使用的工具包需从第三方开源软件库中在线安装 xff0c 因此需执行以下命令 EPEL 的全称叫 Extra Packages for Enterprise Linux EPEL 是由 Fedora 社区打造 x
  • linux系统维护篇:org.gtk.vfs.Daemon: A connection to the bus can‘t be made

    问题 linux centos7 9安装的GNOME桌面莫名其妙不能使用vnc远程 排查 经过定位 发现服务器上vncserver服务无法启动 日志如下 Feb 3 16 30 01 localhost systemd Started Se
  • linux系统维护篇:centos7.9桌面环境安装百度网盘客户端(libstdc++.so.6: version `GLIBCXX_3.4.20‘ not found)

    1 官网下载linux版本rpm包 https pan baidu com download 2 上传到服务进行安装 root 64 dukeServer rpm ivh baidunetdisk 3 5 0 x86 64 rpm 会遇到需
  • nginx代理ftp端口,实现文件传输

    1 需求背景 2 安装nginx 查看nginx离线安装 这里补充下 xff1a 因为代理ftp端口需要用到nginx的stream模块 xff0c 所以在配置nginx的时候需带上参数 xff1a with stream 核心配置 xff
  • Generic family ‘sans-serif‘ not found because none of the following families

    1背景 python使用matplot绘图标注中文时 xff0c 出现乱码 xff0c 部分python代码如下 xff1a 解决中文显示问题 plt rcParams 39 font sans serif 39 61 39 SimHei
  • 实现阿里云服务器内网互通

    1 首先第一步应该是提交工单 xff0c 告知两台服务器的外网IP xff0c 然后通过工单进行反馈 2 如果地域都是一样那就好办很多 xff0c 比如参考官方的案例 xff1a 安全组应用案例 云服务器 ECS 阿里云帮助中心 官方内容如
  • hydra安装及使用

    说明 xff1a hydra是著名黑客组织thc的一款开源的暴力密码破解工具 xff0c 可以在线破解多种密码 官网 xff1a http www thc org thc hydra xff0c 可支持AFP Cisco AAA Cisco
  • 数据库mysql 主从方案

    双机热备的概念简单说一下 xff0c 就是要保持两个数据库的状态自动同步 对任何一个数据库的操作都自动应用到另外一个数据库 xff0c 始终保持两个数据库数据一致 这样做的好处多 1 可以做灾备 xff0c 其中一个坏了可以切换到另一个 2
  • shell工具--sed和awk详解

    grep grep是一款强大的文本过滤工具 xff0c 按照关键字或者正则表达式进行过滤 具体讲解请看博文 这里写链接内容 sed sed是一种流编辑器 xff0c 它是文本处理中非常中的工具 xff0c 能够完美的配合正则表达式使用 1
  • js实现打字机效果---Day06

    我常想象这样一幅画面 xff1a 素雅的大背景 xff0c 伴着可心的音乐 xff0c 优雅旋转着的芭蕾舞者 xff0c 旁边那不断打出的文字 xff0c 仿佛就这样娓娓道来他们那美美的故事 xff1b 也常想象 xff1a 呼喇啦甩动的大
  • 纯css3实现漂亮的对话框----Day07

    姑且先不来讨论css3跟css的区别 xff0c 也不说html和html5的不同 xff0c 虽然这很关键 xff0c 但是现阶段还真的没整利落了 xff0c 姑且就这些应用先用着 xff0c 等自己有些见解了再来探讨那些深层次的问题 先
  • 纯css3实现饼状图-------Day21

    现代网站在商务应用中比较广泛 xff0c 什么oa xff0c 什么erp xff0c 除了导入导出 xff0c 就是数据统计 xff0c 再不然就来个做个报表 xff0c 而饼状图作为数据的一种直观统计显示 xff0c 应用是非常广泛的
  • 你是如何理解var e=e||window.event的------Day26

    你是如何理解var e 61 e window event的 xff1f 相信很多人都能给我个回答说是 xff1a 为了实现多种浏览器兼容 不错 xff0c 确实是为了实现浏览器兼容 xff0c 但是它又是如何实现浏览器兼容的呢 xff1f
  • js实现回放拖拽轨迹-------Day48

    今天有点小高兴 xff0c csdn博客浏览量过万了 xff0c 在过去还从来没有过这么高的浏览量呢 xff0c 不得不说 xff0c 太多时候还是有些矫情 xff0c 可看到这些鼓励还是忍不住高兴啊 xff0c 至少 xff0c 这样让我
  • js实现动态删除表格的行或者列-------Day57

    昨天记录了动态添加表格的一行 xff0c 当然这个一行是指一行数据 xff0c 也就是说一行多少列也是加上的 xff0c 并且第几列的内容都可以添加上 xff0c 先来回顾下它的实现的关键点 xff1a 1 var row 61 table
  • js实现表格的选中一行-------Day58

    最开始想更多的用js来动态操作表格 xff0c 是因为在应用了easyUI之后 xff0c 发现直接写一个 lt table id 61 34 tt 34 gt lt table gt xff0c 这就够了 xff0c 界面里面就剩下这么一
  • 积跬步,聚小流-------关于UML时序图

    uml时序图的存在 在上一篇中记录了uml类图 xff0c 用类图来描述代码中所需要的类以及相互之间的关系 xff0c 也就立体的将整个程序框架展现在了我们面前 xff0c 像一幅画 xff0c 有山有水有人 一张照片只能定格当时的美好 x
  • 积跬步,聚小流------用smartpaginator来做分页

    网络上的实例 xff08 jquery smarypaginator 例图 xff09 如果说是从 百度 上搜索过 jquery分页插件 的朋友 xff0c 相信对上面的图片不会陌生 xff0c 几乎所有介绍 jquery分页插件 的文章中