JSP分页处理

2023-11-01

作为代码萌新的我今天尝试做了一个JSP的分页处理,如果有什么不好的地方请在评论区留下建议(#^.^#)
废话不多说,先看我做的效果图↓↓
这里写图片描述

  我在查询数据的时候使用了异步AJAX,在数据绑定的时候使用的是vue,因为我感觉vue用来绑定数据更方便一点,分页插件使用的是bootsarp的插件,……..至于听别人说vue有分页的功能什么的,我是第一次使用vue,不太清楚,所以本篇文章就按我的方法进行分页吧~~


先说我用到的文件吧~~

  • jar包:① gson-2.2.4.jar
       ② mysql-connector-java-8.0.11.jar
  • 资源文件:① vue.min.js
         ② bootstrap-paginator.js(bootstarp分页插件)
         ③ jquery-3.3.1.min.js
          ④ bootstrap.min.css

不说废话,先看前台代码

<body>
    <div class="marray"><h2>世界所有国家[分页处理]</h2></div>
    <div class="marray"><a href="../index.jsp">返回目录菜单</a></div>
    <div class="marray"  id="table">
        <div class="marray" style="text-align: right;">
            当前第 {{nowPage}} 页,共 {{pageCount}} 页 /
            共 {{dataCount}} 条数据, 当前显示 {{nowDataSize}} 条数据
        </div>
        <table class="table table-bordered table-hover">
            <thead>
                <tr>
                    <th style="text-align: center;">编号</th>
                    <!--....为了省位置,这里的th就切掉了....-->
                    <th style="text-align: center;">代码</th>
                </tr>
            </thead>
            <tbody>
                <tr style="height: 60px;" v-for="item in list" >
                    <td style="text-align: center;vertical-align:middle;">{{item.code}}</td>
                    <!--....为了省位置,这里的td就切掉了....-->
                    <td style="text-align: center;vertical-align:middle;">{{item.code2}}</td>
                </tr>
            </tbody>
        </table>
        <div class="marray">
            <!--这一行是bootstrap分页插件页面用到的代码-->
            <div id="example" style="text-align: center"> <ul id="pageLimit"></ul> </div>
        </div>
    </div>
</body>

这里用到了vue的 v-for 数据迭代,不了解可以看http://www.runoob.com/vue2/vue-loop.html
接下来就是重头戏,我的javascript代码

$(document).ready(function() {
        var pages = 1;//当前页数
        var datasize = 7;//每页的数据量
        var PAGECOUNT = 1;//总页数
        var nowDataSize = 0;
        var datacount = 0;
        //初始化调用一次
        getData();
        //声明vue绑定数据
        var pagedata = new Vue({
            el: '#table',
            data: {
                list : [],
                nowDataSize : nowDataSize,
                dataCount : datacount,
                nowPage : pages,
                pageCount : PAGECOUNT
            }
        });

        //用于查询数据的方法
        function getData() {
            $.ajax({
                type: "POST",
                url: "${pageContext.request.contextPath}/SelectAllCountry2Servlet",
                dataType: "json",
                data: {
                    pages : pages,
                    datasize : datasize
                },
                contentType: "application/x-www-form-urlencoded; charset=UTF-8",
                success: function(result) {
                    //获得数据总数
                    datacount = result["datacount"][0];
                    //计算获得当前的数据量  当然这里这个值也可以从后台一块传来
                    nowDataSize = 0;//初始化这个值
                    for(var key in result["list"]){
                        nowDataSize = nowDataSize + 1;
                    }
                    //计算页面总数
                    PAGECOUNT = Math.ceil(datacount/datasize);
                    //为vue设置值
                    pagedata.list = result["list"];
                    pagedata.pageCount = PAGECOUNT;
                    pagedata.nowPage = pages;
                    pagedata.nowDataSize = nowDataSize;
                    pagedata.dataCount = datacount;

                    //添加分页按钮组
                    $("#pageLimit").bootstrapPaginator({    
                        currentPage: pages,
                        totalPages: PAGECOUNT,
                        numberOfPages:10,//显示的页数
                        bootstrapMajorVersion:3,
                        itemTexts: function (type, page, current) {
                            switch (type) {
                                case "first":
                                    return "首页";
                                case "prev":
                                    return "上一页";
                                case "next":
                                    return "下一页";
                                case "last":
                                    return "末页";
                                case "page":
                                    return page;
                            }
                        },onPageClicked: function(event, originalEvent, type, page){
                            //选择改变事件
                            pages = page;
                            getData();
                        }
                    });
                },
                error: function(result) {
                    console.log("失败");
                }
            });
        }

    });

到此,我们前台就可以向后台取值了,那么后台是怎么把值给了前台的呢,我们看一下

    /*==控制器的doPost方法==*/
    Map<String,List> map = new HashMap<String,List>();
    List listInfo = new ArrayList();
    //获得页面参数
    String pages = request.getParameter("pages").toString().trim();
    String datasize = request.getParameter("datasize").toString().trim();
    //获得并把数据总量加到map中
    int count = bizFactory.getCountryBiz().getCountryCount();
    listInfo.add(count);
    map.put("datacount", listInfo);
    //查询城市列表
    System.out.println(pages    +  "       "  + datasize);
    List list = new ArrayList();
    list = bizFactory.getCountryBiz()
                    .selectSomeCountry(Integer.valueOf(pages), Integer.valueOf(datasize));
    map.put("list", list);
    // 输出返回
    PrintWriter out = response.getWriter();
    // 调用gson的方法将对象打为Json数据格式(字符串)
    Gson gson = new GsonBuilder().setDateFormat("yyyy-MM-dd").create();
    String result = gson.toJson(map);
    System.out.println(result);
    out.write(result);// 注意这里向jsp输出的流,在script中的截获方法

  可以看到上面有两次方法调用,
  第一次是 getCountryCount(),这个方法是我自己写的用于获取该数据表中共有多少条数据,,dao层就不贴全部代码了,就看一下我的sql语句就可以了。

SELECT COUNT(*) FROM country

  第二次是.selectSomeCountry(),这个方法就用于获取数据的,传入有两个参数(当前页码,单页显示的数据量),相信大家看出这sql语句需要两个参数了,也知道这个sql是干啥的,我直接说这两个参数是怎么通过传来的两个参数计算来的吧:参数① ( 当前页面 - 1 )× 单页显示的数据量,参数② 单页显示的数据量。

SELECT * FROM country LIMIT ?,?

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

JSP分页处理 的相关文章

随机推荐

  • 我的电路实践

    任务一 任务二 任务三 任务四
  • 自动解压目录及子目录下所有压缩文件的批处理(偷懒专用^_^)

    以下内容存为 bat文件 置于你需要操作的目录下 双击运行即可自动解压目录及子目录下的所有 rar压缩文件 保持原有目录结构 并在解压后删除原压缩文件 可以根据自己需要对目录等进行修改 改成带参数的批处理或者对特定目录操作的批处理 将这个批
  • caliper的实操与报错合集,超详细的教程

    实操 验证python make g gcc git版本 sudo apt install y python2 7 sudo apt install y pip sudo apt install y make sudo apt instal
  • ACL2022 用于开放域问答的复制增强生成模型 A Copy-Augmented Generative Model for Open-Domain QuestionAnswering

    第一遍 标题 摘要 结论 可以看一看方法和实验部分重要的图和表 这样可以花费十几分钟时间了解到论文是否适合你的研究方向 第二遍 确定论文值得读之后 可以快速的把整个论文过一遍 不需要知道所有的细节 需要了解重要的图和表 知道每一个部分在干什
  • 数据可视化——seaborn(二)

    上一篇文章主要讲述了有关seaborn的一些基础设置 可以让使我们绘制的图形更加饱满 接下来我们来看seaborn可以绘制哪些图形 左边是我们常用的绘图接口 右边则是一些基础设置 还有一些功能有待补充 依次来看这些函数的实现方式和具体功能
  • IPv6 基础知识

    一 包结构 基本的 IPv4 报头包含 12 的字段 20 个字节长 options 和 padding 字段在需要时添加 基本的 IPv6 报头 40 个 8 位 bit 即 40 个字节长 共 8 个字段 下一个报头 Next Head
  • 兔子生兔子问题(java实现)

    一对兔子 从出生后第3个月起每个月都生一对兔子 小兔子长到第三个月后每个月又生一对兔子 假如兔子都不死 问第n个月的兔子对数为多少 分析 第一个月是1对第二个月是1对第三个月是1 1 2对第四个月是2 1 3对第五个月是3 2 5对第六个月
  • MybatisPlus 多租户架构(SaaS)实现

    引言 读写分离要做的事情就是对于一条SQL该选择哪个数据库去执行 至于谁来做选择数据库这件事儿 无非两个 要么中间件帮我们做 要么程序自己做 因此 一般来讲 读写分离有两种实现方式 第一种是依靠中间件 比如 MyCat 也就是说应用程序连接
  • 50_Pandas读取 Excel 文件 (xlsx, xls)

    50 Pandas读取 Excel 文件 xlsx xls 要使用 pandas 将 Excel 文件 扩展名 xlsx xls 作为 pandas DataFrame 读取 请使用 pandas read excel 函数 这里 将描述以
  • python: logHelper

    encoding utf 8 版权所有 2023 涂聚文有限公司 许可信息查看 https docs python org 3 library logging html 描述 https www programcreek com pytho
  • 北京大学肖臻老师《区块链技术与应用》公开课笔记17——ETH数据结构篇1(状态树1)

    北京大学肖臻老师 区块链技术与应用 公开课笔记 以太坊数据结构篇1 状态树1 对应肖老师视频 click here 全系列笔记请见 click here 以太坊数据结构篇1 状态树2请见 click here About Me 点击进入我的
  • uniapp swiper 指示点位置修改 亲测有用

    只需要设置swiper的高度高于子元素swiper item就OK 有效回来点个赞哈
  • 解决UE4缓存使C盘膨胀的问题

    大家好 可能很多新手使用UE4的时候会发现C盘越来越小了 那是因为UE4引擎的缓存文件默认保存在C盘的缘故 下面来告诉大家怎么解决这个问题 概述 一 出现的问题 UE4的缓存文件会导致C盘膨胀 二 解决的方式 请严格按照下列步骤来执行 1
  • springdata JPA@Query注解及@Modifying注解

    Query注解查询适用于所查询的数据无法通过关键字查询得到结果的查询 这种查询可以摆脱像关键字查询那样的约束 将查询直接在相应的接口方法中声明 结构更为清晰 这是Spring Data的特有实现 索引参数与命名参数 1 索引参数如下所示 索
  • c#操作符operate的用法

    operate operate 的用法 看代码 public struct CorePoint
  • 用户自定义类型(User-defined Type)参数的传递

    用户自定义类型 User defined Type 参数的传递 用户自定义类型在VB中是一种重要的数据类型 它为编程者提供了很大的灵活性 使开发人员可以根据需要构造自己的数据结构 它相当于C C 中的结构类型 structure 在VB中
  • 转【】浅谈sql中的in与not in,exists与not exists的区别_

    浅谈sql中的in与not in exists与not exists的区别 1 in和exists in是把外表和内表作hash连接 而exists是对外表作loop循环 每次loop循环再对内表进行查询 一直以来认为exists比in效率
  • 基于Cesium的实景三维模型动态更新-以3Dtiles为例(一)

    一 简介 Cesium众所周知 是一个前端的三维框架 本项目利用Cesium平台来实现实景三维模型的动态更新 不认识Cesium的同学戳这里 cesium中文网 学习cesiumjs 的好地方 伐罗密 实景三维模型 概括来讲就是倾斜摄影三维
  • CocosCreator-3D 3D物体触摸移动(跟随移动)

    版本 cocoscreator3 4 0 基本原理 通过触摸屏幕上的点生成一个射线 通过物理射线检测 获得是否点击到物体 通过射线的检测结果 raycastResults 获得碰撞点 hitPoint 设置物体的x z为碰撞点的x y即可
  • JSP分页处理

    作为代码萌新的我今天尝试做了一个JSP的分页处理 如果有什么不好的地方请在评论区留下建议 废话不多说 先看我做的效果图 我在查询数据的时候使用了异步AJAX 在数据绑定的时候使用的是vue 因为我感觉vue用来绑定数据更方便一点 分页插件使