那一日的约定 2021-12-17 23:42 采纳率: 100%
浏览 33
已结题

jsp分页页码该如何实现每次只显示10个

遇到个问题,使用while循环时不知道该如何控制界面上只显示10个页码数,每次都是输出全部的页码,想实现当页码是第10页时,界面上的页码数显示10~20页以此类推。连接数据库是用Javabean。

img

<%
int pagesize=1;//每页显示几条数据
int id=1;//当前页
int pages=1;//页码
String pPages="";
String nPages="";
int rowcount=0;//页面总数
int pagecount=0;
String path="";
if(request.getParameter("id")!=null){
    try{
        id=Integer.parseInt(request.getParameter("id"));
    }
    catch(Exception e){
        id=1;
    }
}
ResultSet rs =null;
String sql="SELECT count(*)FROM guestbook ";//获得总页数
rs=bb.getResult(sql);
rs.next();
rowcount=rs.getInt(1);
if(rowcount % pagesize==0){
    pagecount=rowcount/ pagesize;
}else{
    pagecount=rowcount/ pagesize+1;
}
pages=id;
if(pages>pagecount){
    pages=pagecount;
}
if(pages<0){
    pages=1;
}
 
sql="select *  from guestbook  order by time desc limit "+(pages-1)*pagesize+","+pagesize+"";
rs=bb.getResult(sql);
%>
<table class="table2" cellspacing="0">
                <tr style="text-align: center;">
                    <td style="width: 260;border-right:1px solid black;">时间</td>
                    <td style="width: 130;border-right:1px solid black;">姓名</td>
                    <td width=600px;>内容</td>
                
                </tr>

                <% while(rs.next()){ %>
                <tr>
                    <td style="width: 260;border-right:1px solid black;"><%=rs.getString("time") %></td>
                    <td style="width: 130;border-right:1px solid black;text-align: center;"><%=rs.getString("name") %></td>
                    <td><%=rs.getString("text") %></td>
                    
                    

                </tr>
                <% } rs.close();
        bb.Release();%>

            </table>
            
            <%if(id==1){ %>
                <span>首页</span>
                <span>上一页</span>
                <%}else{ %>
                <a href="?id=<%=1%>">首页</a>
                <a href="?id=<%=(id-1)%>">上一页</a>
                <%}
            int i=1;
            
            while(i<=pagecount){
                %>
                <a href="?id=<%=i%>"><%=i%></a>
                <%i++;
                
            }
                if(id>=pagecount){%>
                <span>下一页</span>
                <span>尾页</span><br>
                <%}else{%>
                <a href="?id=<%=(id+1)%>">下一页</a>
                <a href="?id=<%=pagecount%>">尾页</a>
                <%} %>


  • 写回答

1条回答 默认 最新

  • 拖下去砍了 2021-12-17 23:50
    关注

    while改成当count>10时显示10条否则全部显示,换页的时候根据当前页动态修改 i 的值

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    问题事件

    • 系统已结题 12月26日
    • 已采纳回答 12月18日
    • 创建了问题 12月17日

    悬赏问题

    • ¥15 求一个智能家居控制的代码
    • ¥15 ad软件 pcb布线pcb规则约束编辑器where the object matpcb布线pcb规则约束编辑器where the object matchs怎么没有+15v只有no net
    • ¥15 虚拟机vmnet8 nat模式可以ping通主机,主机也能ping通虚拟机,但是vmnet8一直未识别怎么解决,其次诊断结果就是默认网关不可用
    • ¥20 求各位能用我能理解的话回答超级简单的一些问题
    • ¥15 yolov5双目识别输出坐标代码报错
    • ¥15 这个代码有什么语法错误
    • ¥15 给予STM32按键中断与串口通信
    • ¥15 使用QT实现can通信
    • ¥15 关于sp验证的一些东西,求告知如何解决,
    • ¥35 关于#javascript#的问题:但是我写的只能接码数字和字符,帮我写一个解码JS问题