页面分页

需求:当数据很多,一个页面难以展现时,便需要分页来实现。

说在前面:
1.每一页展示的数据可以从数据库中抽取出来,数据查询方法中有limit这个方法,limit x,y —–>x表示从第几条数据开始查询,y表示查询多少条数据;
2.数据库数据序号从0开始;
3.Eg:select * from user limit 2,5; 表示从数据库第三条数据开始查询,查询5条数据,既查询到7;


下面具体代码实现,对于web页面的上下页用js控制,核心在于js的控制,对于其他的数据库连接和web页面处理我用的是Mybaties和springMVC框架

要实现的web页面
这里写图片描述

代码:

    <button onclick="firstYe()">首页</button><button onclick="lastPage()">上一页</button><span id="num" style="color: blue">${PageNum}</span>/共<span id="lastNum">${num}</span><button onclick="nextPage()">下一页</button>跳转到<input type="text" size="1" onblur="Page(this.value)"><button onclick="finalPage()">最后一页</button>

这里写图片描述

JS实现 :int类型数字必须用parseInt()方法转换下,js是弱语言,数字不处理会默认字符串拼接

//上一页
function lastPage() {var num = parseInt(document.getElementById("num").innerHTML); //当前页数if (num > 1) {      //判断是否页数超出最小范围var y = num - parseInt(1);      //页数-1location = 'showPage?PageId=' + y;      //定位到上一页} else {alert("已经是第1页了...");}}//下一页
function nextPage() {var lastNum=parseInt(document.getElementById("lastNum").innerHTML);//总页数var num = parseInt(document.getElementById("num").innerHTML);   //当前页数if(num<lastNum){    //判断是否页数超出最大范围var y = num + parseInt(1);  //页数+1location = 'showPage?PageId=' + y;  //定位到下一页}else{alert("已经是最后一页");}
}//首页
function firstYe() {location = 'showPage?PageId=' + 1;  //跳到第一页
}//调到指定页面
function Page(id) {location = 'showPage?PageId=' + id; 
}//最后一页
function finalPage(){var lastNum=parseInt(document.getElementById("lastNum").innerHTML); //总页数location = 'showPage?PageId=' + lastNum;
}

数据库查询语句
我的用的是myBaties框架,其他实现的认真看看语句是相同的
这里写图片描述
上面查询数据总数目,用于处理跳转最后一页操作

service层处理每次查询的页面关系,我们每次翻页变化的是页面,而sql查询数据是具体数据序号,所以页数和数据序号存在一个转换关系(数据库数据序号从0开始),id=(x-1)*y; id是数据查询起始数目,x是页数,y是你需要每页展示数据的数目。

public List<User> findAllByPage(int id) {SqlSession s = MyBatiesUtils.getSqlSession();int n=(id-1)*3;   //控制每次查询起始数据的序数,每页显示3条数据List<User> list = s.selectList(namespace + ".findAllByPage",n);s.close();return list;}

求取总页数,使用总数据条数除以每页显示条数,这里可以使用Math类的向上取整ceil()方法

public int findNum() {SqlSession s = MyBatiesUtils.getSqlSession();int n=s.selectOne(namespace+".findNum");int pageNum=(int) Math.ceil(n*1.0/3); //数据总数除以每页显示数目,结果向上取整s.close();return pageNum;}

实现图
这里写图片描述


原代码http://download.csdn.net/download/qq_36330228/10118771

转载于:https://www.cnblogs.com/wangqilong/p/9417518.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/428585.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

typora打开pdf文件提示文件过大_Win7/Win10拷贝到U盘容量足够却提示文件过大的解决方法...

前段时间&#xff0c;装机之家分享了系统安装的教程&#xff0c;不过有用户在拷贝系统镜像文件的时候&#xff0c;出现了系统提示文件过大&#xff0c;但是U盘容量足够大&#xff0c;这是什么情况呢&#xff1f;下面装机之家分享的Win7/Win10系统下拷贝到U盘容量足够却提示文件…

图像卷积与滤波的一些知识点

http://blog.csdn.net/zouxy09/article/details/49080029 之前在学习CNN的时候&#xff0c;有对卷积进行一些学习和整理&#xff0c;后来就烂尾了&#xff0c;现在稍微整理下&#xff0c;先放上来&#xff0c;以提醒和交流。 一、线性滤波与卷积的基本概念 线性滤波可以说是图像…

1到10选一个数字读心术_厉害了!quot;广东110“互联网报警满足您多场景报警需求!...

01报警人哎&#xff0c;110&#xff0c;这边打架了。(南方口音)警察在哪里?报警人在fa ben 市场门口嘛。警察什么“发奔”市场&#xff0c;没听过这个地方&#xff0c;你能讲清楚点吗?报警人就是那个卖“发发”草草的市场嘛&#xff0c;哎&#xff0c;这都不知道&#xff0c;…

学生免费用IDEA

第一步&#xff1a;官网免费申请 进去之后点击立即申请。 来到这个界面&#xff1a; 这时候有些博主就瞎写了&#xff0c;搞的我弄半天电子邮件。 其实在校大学生应该点击官方文件 按照要求填写就行了&#xff0c;自己的邮箱&#xff0c;学信网的证明&#xff0c;学校名称等…

网页设计如何排成一列_网页设计如何影响以及改善SEO?

在当今的SEO世界中&#xff0c;网站设计实践也起着关键作用。用户体验已成为搜索引擎排名的关键因素。因此&#xff0c;您网站的设计以及用户与网站的交互方式会直接影响您网站在搜索结果中的排名。在本文中&#xff0c;我们将重点介绍一些可能对网站的SEO性能有直接影响的网站…

Tensorflow模型加载与保存、Tensorboard简单使用

先上代码&#xff1a; from __future__ import absolute_import from __future__ import division from __future__ import print_function # -*- coding: utf-8 -*- """ Created on Tue Nov 14 20:34:00 2017author: HJL """# Copyright 2015 T…

cesium添加填充_Cesium中级教程1 - 空间数据可视化(一)

Cesium中文网&#xff1a;http://cesiumcn.org/| 国内快速访问&#xff1a;http://cesium.coinidea.com/本教程将教读者如何使用Cesium的实体&#xff08;Entity&#xff09;API绘制空间数据&#xff0c;如点、标记、标签、线、模型、形状和物体。不需要Cesium的先验知识&#…

atomic原子类实现机制_并发编程:并发操作原子类Atomic以及CAS的ABA问题

本文基于JDK1.8Atomic原子类原子类是具有原子操作特征的类。原子类存在于java.util.concurrent.atmic包下。根据操作的数据类型&#xff0c;原子类可以分为以下几类。基本类型AtomicInteger&#xff1a;整型原子类AtomicLong&#xff1a;长整型原子类AtomicBoolean&#xff1a;…

c# winform窗体如何设置才可以不能随意拖动大小

执行以下两个步骤&#xff0c;能够禁止用户改变窗体的大小 &#xff08;一&#xff09;步骤1 设置窗体的FormBorderStyle属性为下列五个值中的任意一个 None&#xff1a;将窗口设置为无边框、无标题栏。用户无法改变窗口的大小&#xff0c;也无法改变窗口显示的位置&#xff1b…

增加数据_咱晋城人口又增加了?最新数据来了

微信广告合作/13903568008、13663561666近日山西省统计局山西省人口抽样调查办公室联合发布2019年山西省人口变动情况抽样调查主要数据公报全省哪个地市人最多&#xff1f;男女比例如何&#xff1f;……1常住人口根据抽样调查全省人口出生率为9.12‰比上年下降0.51个千分点人口…

怎么让wegame适应屏幕大小_iOS的五大设计原则:统一化和适应化原则

昨天米醋跟大家分享了iOS的五大设计原则中凸显内容原则&#xff0c;那么今天我们继续来说说统一化原则和适应化原则。统一化原则统一化原则主要体现在视觉统一和交互统一两个方面。在视觉统一方面&#xff0c;要讲究字体、颜色和元素的统一性&#xff0c;标题字号的统一&#x…

语言求圆周率近似值改错_新证明解决了如何求无理数的近似值

原文&#xff1a;Kevin Hartnett&#xff0c;QuantaMagazine日前&#xff0c;一份新鲜出炉的论文证明了近80年悬而未决的达芬-谢弗&#xff08;Duffin-Schaeffer&#xff09;猜想&#xff0c;让数轴上讳莫如深的部分再也不如表面看来那么遥不可及。达芬-谢弗猜想的证明完美解答…

谷歌翻译无法连接网络_window10无法连接网络

很多朋友都将电脑的系统升级到Win10&#xff0c;如果遇到了Win10系统无法连接网络该如何解决&#xff0c;下面就为大家介绍一下解决的方法。window10无法连接网络一、检查路由器1、重新启动(断电10秒钟) 无线路由器和猫(调制解调器)&#xff0c;有时候是路由器的故障&#xff1…

获取弹出的窗口_Win7系统如何获取设置everyone权限的问题

一位win7之家系统的小伙伴&#xff0c;想要在电脑系统中获取everyone权限&#xff0c;但是不知道该怎么做&#xff0c;对于Win7电脑如何获取设置everyone权限这个问题&#xff0c;小编觉得我们可以在电脑的计算机中找到相关的磁盘&#xff0c;打开磁盘属性然后在安全选项中进行…

异步请求中jetty处理ServletRequestListener的坑

标题起得比较诡异&#xff0c;其实并不是坑&#xff0c;而是jetty似乎压根就没做对异步request的ServletRequestListener的特殊处理&#xff0c;如果文中有错误欢迎提出&#xff0c;可能自己有所疏漏了。 之前遇到了一个bug&#xff0c;在Listener中重写requestDestroyed清理资…

华为h22h05服务器做raid_华为V5服务器 RAID控制卡(LSI SAS3008IR)

提供高速接口和模块LSI SAS3008IR的PCIe Core提供PCIe x8接口&#xff0c;每lane速率为8Gb/s&#xff0c;可以兼容x1、x2、x4配置&#xff1b;支持PCIe 3.0规格&#xff0c;兼容PCIe 2.x和PCIe 1.x。LSI SAS3008IR的SAS模块提供SAS功能&#xff0c;并定义支持的硬盘速率。LSI S…

css加了固定定位就不显示内容_前端开发必备,学好”定位“向菜鸟说拜拜

众所周知&#xff0c;前端CSS中&#xff0c;盒模型、浮动、定位为必须掌握的三座大山。今天就来聊聊定位的那些事。定位是什么&#xff1f;先来看看哪些场景用到定位&#xff0c;如下图所示&#xff0c;凡是有盒子压住另一个盒子的地方都可定位&#xff0c;因为用浮动做不了&am…

vscode更换主题的插件_VScode 插件开发(三)主题

咱们上回书说道&#xff0c;安装完基础环境&#xff0c;我们要来玩自己的主题了1. 创建一个主题项目$ yo code选中 New Color Theme接下来照图中所选&#xff0c;完成项目创建(简单英语不做解释)打开项目如图2. 配置文件2.1 themes这个文件夹包含主题配置文件&#xff0c;可以新…

软件工程概论课后作业01

1. 网站系统开发需要掌握的技术 ①java语言 Java语言体系比较庞大&#xff0c;包括多个模块。从WEB项目应用角度讲有JSP&#xff0c;Servlet&#xff0c;JDBC&#xff0c;JavaBean&#xff08;Application&#xff09;四部分技术。JDBC可做三件事情&#xff1a;与数据库建立连接…

mysql 参数bug_MySQL 的这个 BUG,坑了多少人?

作者&#xff1a;腾讯数据库技术来源&#xff1a;cloud.tencent.com/developer/article/1367681▌问题描述近期&#xff0c;线上有个重要Mysql客户的表在从5.6升级到5.7后&#xff0c;master上插入过程中出现"Duplicate key"的错误&#xff0c;而且是在主备及RO实例上…