JSP网站开发基础总结《八》

JSP的学习总结到本篇已经八篇了,内容比较多,但都是实战,本篇最后为大家介绍一个小效果:百度分页。就是当我们遍历的数据对象较多时,这时我们就会看到了这个效果了,那他是如何实现的呢?下面我们就一起学习一下。

 1、分页数据获取方法:

  获得数据总数:

public int getSize() {
        int num = 0;
        Connection conn = null;
        Statement st = null;
        ResultSet rs = null;
        conn = DBO.getConnection();
        String sql = "select count(*) from students";
        try {
            st = conn.createStatement();
            rs = st.executeQuery(sql);
            rs.next();
            num=rs.getInt(1);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return num;
    }

  计算一共分几页:

public int getPageCnt(int pageRec) {
        int page = 0;
        int size = this.getSize();
        if(size>0){
            page = (size-1)/pageRec+1;
        }
        return page;
    }

  获得在该页需要显示的数据:

public List<Student> getSome(int pageNo, int pageRec) {
        List<Student> list = new ArrayList<Student>();
        Connection conn = null;
        Statement st = null;
        ResultSet rs = null;
        try {
            conn=DBO.getConnection();
            String sql="select * from students limit ";
            int num = this.getSize()-pageNo*pageRec;
            int a = this.getSize()-(pageNo-1)*pageRec;
            if(num<0){
                num=0;
            }
            sql+=(num)+","+ a;
            st=conn.createStatement();
            rs=st.executeQuery(sql);
            while(rs.next()){
                Student stu = new Student();
                stu.setId(rs.getInt("id"));
                stu.setName(rs.getString("username"));
                stu.setSex(rs.getInt("sex"));
                stu.setYear(rs.getInt("age"));
                stu.setFrom(rs.getString("form"));
                stu.setSchool(rs.getString("school"));
                list.add(stu);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally{
            DBO.close(rs, st, conn);
        }
        return list;
    }

 2、实现页面效果代码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" errorPage="error.html"%>
<%@page import="com.mysql.jsp.student.Student"%>
<%@page import="com.mysql.jsp.sever.StudentMaImp"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">

    <title>百度分页效果</title>

    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">

  </head>

  <body>
  <%
           int pageNo=1;
           if(request.getParameter("p") !=null){
            pageNo=Integer.parseInt(request.getParameter("p"));
        }
           int pageRec=5;//每页显示的数据条数
           StudentMaImp smi = new StudentMaImp();
        List<Student> list = smi.getSome(pageNo, pageRec);
        int recCnt=smi.getSize();//得到总记录数
        int pageCnt=smi.getPageCnt(pageRec);//得到总页数
   %>
    <center>
        <h1>百度分页效果</h1>
        <hr/>
        <table border="1" width="80%">
            <TR>
                <td>编号</td><TD>ID</TD><td>姓名</td><td>性别</td><td>年龄</td><td>家乡</td><td>学校</td>
            </TR>
            <%
                if(list.size()!=0 && pageNo>1 ){
                    for(int i=list.size()-1,j=1; i>=0; i--,j++){
                        Student student = list.get(i);
            %>
                    <tr><td><%=j %></td><TD><%=student.getId() %></TD><td><%=student.getName() %></td><td><%if(student.getSex()==1){ %>男<%}else{ %>女<%} %></td><td><%=student.getYear() %></td><td><%=student.getFrom() %></td><td><%=student.getSchool() %></td></tr>
            <%
                    }
                }else{
                    for(int i=list.size()-1,j=1; i>=0&&list.size()!=0; i--,j++){
                        Student student = list.get(i);
            %>
                    <tr><td><%=j %></td><TD><%=student.getId() %></TD><td><%=student.getName() %></td><td><%if(student.getSex()==1){ %>男<%}else{ %>女<%} %></td><td><%=student.getYear() %></td><td><%=student.getFrom() %></td><td><%=student.getSchool() %></td></tr>
             <%
                    }
                 }
             %>
             <tr>
                 <td colspan="7" align="center">
                   <% if(pageNo!=1){ %>
                       <a href="All_BaiDu.jsp?p=1"><span>首页</span></a>
                  <%} %>
                  <% if(pageNo>1){ %>
                    <a href="All_BaiDu.jsp?p=<%=pageNo-1 %>"><span>上一页</span></a>
                  <%} %>
                   <%
                       for(int i=1;i<=pageCnt;i++){
                       if(i!=pageNo){
                   %>
                       <a href="All_BaiDu.jsp?p=<%=i %>"><span><%=i%></span></a>
                <%}else{ %>
                        <span><%=i%></span></a>
                   <%}}%>
                     <% if(pageNo!=pageCnt){ %>
                       <a href="All_BaiDu.jsp?p=<%=pageNo+1 %>"><span>下一页</span></a>
                  <%} %>
                  <% if(pageNo!=pageCnt){ %>
                    <a href="All_BaiDu.jsp?p=<%=pageCnt %>"><span>尾页</span></a>
                  <%} %>
                 </td>
             </tr>
        </table>
    </center>
  </body>
</html>

  效果图:

  

  好了,到这里我们最简单的百度分页效果就实现了,具体的美化工作,就需要我们的css+div+javascript知识了,大家可以学习一下,对做网页帮助很大。



  关于JSP的基础知识总结,到今天就为大家总结完毕,共计8篇博客,由于文字描述的局限,所以大家有什么疑问可以留言,我会一一为大家解答。

  总结了这么多,最后给大家聊几句,学习JSP之前大家尽量先学习一下JAVASE的基础知识,对你理解JSP中的代码帮助很大,当然如果你对网站开发很感兴趣,可以学一下HTML之后再来学习JSP,这样对你了解里面的JSP语句帮助很大。不过有必要说一点的是,JSP开发现在远没有PHP开发那么受关注,PHP开发无须太多的基础,而JSP开发需要有一定的JAVA基础。大家如果没有JAVA基础,建议大家学习PHP,同样可以达到动态网站的开发的目的,而且PHP开发对于微信端开发很方便,所以大家如果对于JSP的学习感觉压力较大,建议大家学习PHP,不过任何一门技术刚刚接触时,都会存在很多的不懂,重要的是坚持,各种技术之间都是相通,当大家真正掌握一门技术后,再去接触别的技术,就会达到事半功倍的效果。

  最后祝各位在程序猿这条路上能找到属于自己的蓝天。

本文章由 造句大全 www.zaojuzi.com 整理发布

时间: 2024-10-05 12:52:26

JSP网站开发基础总结《八》的相关文章

JSP网站开发基础总结《二》

有了上一篇的学习,我相信大家对于JSP一定有了一定的认识,从今天开始我们真正开启JSP模式,如果你有HTML的基础,那学起JSP来也就方便了很多了,首先JSP做为网站开发语言,它与HTML有很多相似的地方.网站是什么?网站就是通过一个个网页叠加起来的,通过一定的相互关联,最后便组成了网站,那既然是由一页页的网页组成的,我们就先从网页开始进入我们JSP开发世界. JSP网页与传统的HTML网页,基本语法方面是相通的,HTML中的语法规则,在JSP网页中同样适用,不同的是HTML网页的后缀名为.ht

JSP网站开发基础总结《一》

经过JAVASE的学习相信大家对JAVA已经不再陌生,那么JAVA都可以干什么呢?做算法.应用程序.网站开发都可以,从今天开始为大家奉上JAVAEE之JSP动态网站开发基础总结. 既然是动态网站开发,那它与传统的静态网站有什么区别呢?动态两字体现在什么地方?何为动态网站呢?相信学过HTML的小伙伴都知道,HTML是一个非常强大的网站开发语言,在没有出现动态网站开发语言之前,它被奉为网站开发利器,不过对于HTML网站开发存在一个问题,就是网站没办法实时更新,网站一旦开发完成不论经过多长时间,网站上

JSP网站开发基础总结《四》

经过前几篇的摸爬滚打,下面我们就开始我们真正的数据库操作了,本篇重点在于如何在网站端编写数据库操作语句,内容不多,就是我们常见的增删改查. 0.数据库对象创建: 在JAVASE基础知识总结时,就为大家点明了,JAVA是一种面向对象编程语言,所以我们再进行数据库创建之前,要先创建一个对象类. /* * 实例化数据库中的对象 */ public class Student { private int id;//学生ID private String name;//学生姓名 private int s

JSP网站开发基础总结《十四》

对于JSP的知识总结,已经为大家分享的差不多了,本篇就为大家做一下最后总结,本篇总结的主题是文件上传和下载,在之前的随笔中也有为大家分享过文件上传和下载的知识,不过都是通过JAVA提供的上传下载类实现的,本篇将通过文件输入输出流的方式为大家精讲一下文件的上传和下载实现,我相信当你了解了底层的实现后,会很方便你对于文件的上传和下载进行拓展.好了废话不多说,下面我们开始本篇的总结. 1.上传分析: 文件上传就是,我们通过Form表单中的input属性,向后台发送用户需要上传的文件,后台当发现用户发送

JSP网站开发基础总结《九》(转)

本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻松的完成之前的那个功能了,而且可以在很多地方使用,非常实用.废话不多说,下面开始简单为大家介绍一下JSP提供的过滤器类. 1.过滤器简介: 过滤器是什么?过滤器就是根据过滤规则对过滤源进行过滤,然后得到过滤结果.Web过滤器的是什么呢?首先Web过滤器的过滤源是用户的各种请求,过滤规则是开发人员实现

JSP网站开发基础总结《九》

本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻松的完成之前的那个功能了,而且可以在很多地方使用,非常实用.废话不多说,下面开始简单为大家介绍一下JSP提供的过滤器类. 1.过滤器简介: 过滤器是什么?过滤器就是根据过滤规则对过滤源进行过滤,然后得到过滤结果.Web过滤器的是什么呢?首先Web过滤器的过滤源是用户的各种请求,过滤规则是开发人员实现

JSP网站开发基础总结《十二》

前两篇已经简单为大家介绍了一下,有关Filter接口的知识,本篇就让我们以一个登录小功能,来具体实现一下过滤器的作用,便于大家掌握.具体为大家介绍一下如何使用Filter对访问进行过滤,及如何防止中文乱码的问题,内容不多,大家只要简单一练习便可以掌握. 1.登录表单: 和一般的表单没有任何区别,大家可以新建一个Login.jsp作为登录界面,在其中添加一个表单即可. <body> <center> <form method="post" action=&q

JSP网站开发基础总结《十》

经过上一篇的介绍相信大家对JSP提供的过滤器一定有了一个概念,本篇我们就一起再来研究一下关于创建多个过滤器时,如果有两个以上过滤器的过滤规则相同,那么这些过滤器的执行顺序如何呢?答案是根据我们在web.xml中声明的先后顺序进行执行,也就是先声明的先执行,后声明的后执行.文字的描述大家可能还是不明白,下面就让我们用程序验证一下. 1.新建Filter类: 因为我们需要完成对于多个过滤器的,执行时的先后顺序判断,所以我们至少需要新建两个Filter类. a.firstFilter.java: pu

JSP网站开发基础总结《七》

按照计划本篇将为大家总结搜索功能的两种实现:确定搜索与模糊搜索.所谓精确搜索便是指,根据用户的输入的搜索内容,在数据库中寻找具有一一对应的关系的数据,一般都是用户在数据库中的主键值.而模糊搜索,是一种根据用户输入的信息,进行匹配,将具有相似信息的数据对象返回给用户.这两者在代码上的区别仅仅在于sql语句不同.下面就具体为大家介绍一下. 搜索输入框的设计,在上一篇中已经为大家介绍过,这里就不再赘述.下面直接开始我们本篇的内容. 1.精确搜索: 用于搜索的java方法: public Student