JSP分页处理

2 篇文章 0 订阅
2 篇文章 0 订阅

作为代码萌新的我今天尝试做了一个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 ?,?

  • 6
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己收集的jsp分页代码。对于北大青鸟Y2的学员可能有用吧。自己也在做这个项目。这里有增、删、该、查加分页。有上一页、下一页、首页、尾页、第几页、还有带数字和点的分页。可以说是非常好的分页代码。想要的朋友自己处下载 <%@ page contentType="text/html; charset=GB2312" language="java" import="java.sql.*" errorPage="" %> <%@ page import="java.io.*" %> <%@ page import="java.util.*" %> <% java.sql.Connection sqlCon; //数据库连接对象 java.sql.Statement sqlStmt; //SQL语句对象 ResultSet sqlRst=null; //java.sql.ResultSet sqlRst; //结果集对象 java.lang.String strCon; //数据库连接字符串 java.lang.String strSQL; //SQL语句 int intPageSize; //一页显示的记录数 int intRowCount; //记录总数 int intPageCount; //总页数 int intPage; //待显示页码 java.lang.String strPage; int i; //设置一页显示的记录数 intPageSize = 2; //取得待显示页码 strPage = request.getParameter("page"); if(strPage==null){ //表明在QueryString中没有page这一个参数,此时显示第一页数据 intPage = 1; } else{ //将字符串转换成整型 intPage = java.lang.Integer.parseInt(strPage); if(intPage<1) intPage = 1; } %><% String DBUser="sa"; String DBPassword="88029712"; //String DBServer="127.0.0.1"zjprice; String DBUrl="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs"; //创建语句对象 //Class.forName("org.gjt.mm.mysql.Driver").newInstance(); Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance(); sqlCon=java.sql.DriverManager.getConnection(DBUrl,DBUser,DBPassword); sqlStmt=sqlCon.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY); //执行SQL语句并获取结果集 String sql=null; String search=""; String ToPage=request.getParameter("ToPage"); if(request.getParameter("search")!=null &&!request.getParameter("search").equals("")) {search=new String(request.getParameter("search").trim().getBytes("8859_1")); } sql="select top 50 au_id,au_lname from authors "; /*sql="select*from ta,tb where id like'%"+search+"%'"; sql=sql+"or title like'%"+search+"%'"; sql=sql+"or time like'%"+search+"%'"; sql=sql+"or con like'%"+search+"%'"; sql=sql+"order by id";*/ sqlRst=sqlStmt.executeQuery(sql); //获取记录总数 sqlRst.last(); intRowCount = sqlRst.getRow(); //记算总页数 intPageCount = (intRowCount+intPageSize-1) / intPageSize; //调整待显示的页码 if(intPage>intPageCount) intPage = intPageCount; %> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>test</title> </head> <body> <table border="1" cellspacing="0" cellpadding="0"> <tr> <th>标题id</th> <th>内容表</th> </tr> <% if(intPageCount>0) { //将记录指针定位到待显示页的第一条记录上 sqlRst.absolute((intPage-1) * intPageSize + 1); //显示数据 i = 0; while(i<intPageSize && !sqlRst.isAfterLast()){ %> <tr> <td> <%=sqlRst.getString(1)%> </td> <td> <%=sqlRst.getString(2)%> </td> </tr> <% sqlRst.next(); i++; } } %> <tr><td colspan="8">共有<font color=red><%= intRowCount %></font>条记录 当前<font color=red><%=intPage%>/<%=intPageCount%></font>页  <% if(intPageCount > 1){ %> <% if(intPage !=0){%> <a href="mysqlpage.jsp">首页</a> <%}if(intPage != 1){%><a href="mysqlpage.jsp?page=<%= intPage - 1 %>">上一页</a> <%}if(intPage<intPageCount){%><a href="mysqlpage.jsp?page=<%=intPage+1%>">下一页</a><%}%> <a href="mysqlpage.jsp?page=<%= intPageCount %>">尾页</a> <% } %>跳转到 <select name="page" onChange="javascript:this.form.submit();"> <% for(i=1;i<=intPageCount;i++){%> <option value="<%= i %>" <% if(intPage == i){%>selected<% } %>><%= i %></option> <% } %> </select>页 <%int m,n,p; %> <%if (intPage>1){ if(intPage-2>0){ m=intPage-2;} else { m=1;} if(intPage+2<intPageCount){ n=intPage+2;} else{ n=intPageCount; }%> 转到页码: [ <% for(p=m;p<=n;p++) { if (intPage==p){ %> <font color="black"><%=p %></font> <% } else{%> <a href=?page=<%=p %>><font color=red>[<%=p %>]</font></a> <% } }%>]<%} %> </td></tr> </table> </body> </html> <% //关闭结果集 sqlRst.close(); //关闭SQL语句对象 sqlStmt.close(); //关闭数据库 sqlCon.close(); %>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值