从sevlet向jsp前台传一个List,如何对这个List进行分页显示

在jsp前台如何对List中的数据进行分页显示!!!

第1个回答  2009-08-10
给你代码看看啊;首先要编写一个javabean 叫
package sample.javaBean;
import sample.javaBean.ConnDb;
import java.util.List;
import java.util.ArrayList;
public class Paination {

private int currentPage;
private int totalPages;
private int pageRows=2;
private int totalRows;
private int pageStartRow;
private int pageEndRow;
private boolean hasPreviousPage;
private boolean hasNextPage;
private List<Object[]>totalList;

public void selectBySQL(){//这个方法主要是输出数据库里信息,就是你在servlet里把数据库信息放到list里一个道理:
List<Object[]> notes=new ArrayList<Object[]>();
ConnDb con=ConnDb.createInstance();
try{

String sql="select * from tb_type order by type_order";
con.setRs(con.query(sql));

while(con.getRs().next()){
Object[] note=new Object[5];
for(int i=0;i<5;i++){
note[i]=con.getRs().getObject(i+1);
}
notes.add(note);
}
con.getRs().close();
}catch (Exception e){
e.printStackTrace();
}
con.closeCon();
totalList=notes;
initPageBean(totalList,pageRows);

}
//分页的一个方法
public void initPageBean(List<Object[]>totalList,int pageRows){
this.totalList=totalList;
this.pageRows=pageRows;
this.totalRows=totalList.size();
this.currentPage=1;
if(totalRows%pageRows==0){
totalPages=totalRows/pageRows;
if(this.totalRows==0){
this.pageRows=0;
}
}else{
totalPages=totalRows/pageRows +1;
}
this.hasPreviousPage=false;
if(currentPage==totalPages){
hasNextPage=false;
}else{
hasNextPage=true;
}
this.pageStartRow=1;
if(totalRows<pageRows){
this.pageEndRow=totalRows;
}else{
this.pageEndRow=pageRows;
}

}
//当前页的方法
public List<Object[]> getCurrentPageList(){
if(currentPage*pageRows<totalRows){
pageEndRow=currentPage*pageRows;
pageStartRow=pageEndRow-pageRows;
}else{
pageEndRow=totalRows;
pageStartRow=pageRows*(totalPages-1);
}
List<Object[]>pageList=new ArrayList<Object[]>(pageEndRow-pageStartRow+1);
if(totalRows!=0){
for(int i=pageStartRow;i<pageEndRow;i++){
pageList.add(totalList.get(i));
}
}
return pageList;
}
//上一页的一个方法
public List<Object[]> getPreviousPageList(){
currentPage=currentPage-1;
if(currentPage<1){
currentPage=1;
}
if(currentPage>=totalPages){
hasNextPage=false;
}else{
hasNextPage=true;
}
if((currentPage-1)>0){
hasPreviousPage=true;
}else{
hasPreviousPage=false;
}
List<Object[]> pageList=this.getCurrentPageList();
return pageList;
}
//下一页的一个方法
public List<Object[]> getNextPageList(){
currentPage=currentPage+1;
if(currentPage>totalPages){
currentPage=totalPages;
}
if((currentPage-1)>0){
hasPreviousPage=true;
}else{
hasPreviousPage=false;
}
if(currentPage>=totalPages){
hasNextPage=false;
}else{
hasNextPage=true;
}

List<Object[]> pageList=this.getCurrentPageList();
return pageList;
}

public List<Object[]> AppointPageList(int currentPage){
this.currentPage=currentPage;
if(currentPage>this.totalPages){
this.currentPage=this.totalPages;
}
if(currentPage<1){
this.currentPage=1;
}else{
hasPreviousPage=false;
}
if(currentPage>1){
this.hasPreviousPage=true;
}else{
this.hasPreviousPage=false;
}
if(this.currentPage<this.totalPages){
this.hasNextPage=true;
}else{
this.hasNextPage=false;
}
List<Object[]> pageList=this.getCurrentPageList();
return pageList;
}
public int getCurrentPage() {
return currentPage;
}
public boolean isHasNextPage() {
return hasNextPage;
}
public boolean isHasPreviousPage() {
return hasPreviousPage;
}
public int getPageEndRow() {
return pageEndRow;
}
public int getPageRows() {
return pageRows=1;
}
public int getPageStartRow() {
return pageStartRow;
}
public List<Object[]> getTotalList() {
return totalList;
}
public int getTotalPages() {
return totalPages;
}
public int getTotalRows() {
return totalRows;
}

}

下面是jsp里分页显示的代码:
<body>
<table align="center" border="1" height="150">
<jsp:useBean id="pa" class="sample.javaBean.Paination" scope="session"/>
<%

pa.selectBySQL();
List<Object[]> notes=pa.getCurrentPageList();

for(int m=0;m<notes.size();m++){

out.println("<tr align='center' bgcolor='#FFCC99'>");
Object[] note=notes.get(m);
for(int n=0;n<note.length;n++){
out.println("<td>"+note[n]+"</td>");
}
out.println("<br>");
out.println("</tr>");
}
%>

<form action="index.jsp" method="post" name="page" onsubmit="return checkPage(page)">
<tr align="right">
<td>
共有<font color="red" size="1"><%=pa.getTotalRows() %></font>条记录
当前是第<font color="red" size="1"><%=pa.getCurrentPage()+"/"+pa.getTotalPages() %></font>页
<%if(pa.isHasPreviousPage())
out.print("<a href='lunta/index2.jsp?requestPage=previousPage'>上一页</a>"); %>
<%if(pa.isHasNextPage())
out.print("<a href='lunta/index2.jsp?requestPage=nextPage'>下一页</a>"); %>

</td>
</tr>
</form>

</table>
</body>
下面是index2.jsp
<body>
<% Paination pa=(Paination)session.getAttribute("pa"); %>
<table align="center" border="1" height="30" width="500">

<%

List<Object[]> notes=new ArrayList<Object[]>();
String requestPage=request.getParameter("requestPage");
if(requestPage.equals("previousPage")){
notes =pa.getPreviousPageList();
}else if(requestPage.equals("nextPage")){
notes=pa.getNextPageList();

}
for(int m=0;m<notes.size();m++){

out.println("<tr align='center' height='30' bgcolor='#FFCC99'>");
Object[] note=notes.get(m);
for(int n=0;n<note.length;n++){
out.println("<td height='30'>"+note[n]+"</td>");
}
out.println("<br>");
out.println("</tr>");
}

%>
</table>
<table align="center" border="1" height="30" width="500">

<form action="index.jsp" method="post" name="page" onsubmit="return checkPage(page)">
<tr align="right" width="300">
<td>
共有<font color="red" size="1"><%=pa.getTotalRows() %></font>条记录
当前是第<font color="red" size="1"><%=pa.getCurrentPage()+"/"+pa.getTotalPages() %></font>页
<%if(pa.isHasPreviousPage())
out.print("<a href='lunta/index2.jsp?requestPage=previousPage'>上一页</a>"); %>
<%if(pa.isHasNextPage())
out.print("<a href='lunta/index2.jsp?requestPage=nextPage'>下一页</a>"); %>
第<input type="text" name="requestPage" size="3" maxlength="2">页
<input type="submit" value="转到>>">

</td>
</tr>
</form>

</table>

</body>
楼主细细分析,应该能看懂的啊!如果有必要你可以问我啊!本回答被提问者采纳

怎么将从servlet拿到的list集合用json数据显示到jsp页面?
可以这样做,返回类型为html格式,把集合显示做成单个页面(userlist.jsp),用div包含该页面,后台跳转到该页面,把div的html替换成返回来的html,页面:\\x0d\\x0a \\x0d\\x0a\\x0d\\x0a\\x0d\\x0avar submitUrl = "AdminMangeServlet";\\x0d\\x0a \\x0d\\x0a $.ajax({\\x0d\\x0a url: submitUrl,\\x...

在JSP中如何实现分页技术啊?
目前比较广泛使用的分页方式是将查询结果缓存在HttpSession或有状态bean中,翻页的时候从缓存中取出一页数据显示。这种方法有两个主要的缺点:一是用户可能看到的是过期数据;二是如果数据量非常大时第一次查询遍历结果集会耗费很长时间,并且缓存的数据也会占用大量内存,效率明显下降。 其它常见的方法还有每次翻页都查询一...

jsp+servlet分页,点下一页,下一页的内容接上一页的内容显示,怎么办?
int prevStart=0;\/\/前一页 int nextPage=0;\/\/下一页 int lastRec=0; \/\/最后一页记录的标记 int lastStartRecord=0;\/\/最后一页开始显示记录的编号 public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { \/\/获取需要显示的页数,由用...

如何在javaservlet和jsp间互传数据
1、利用ServletContext这个web全局上下文来共享数据 servlet中getServletContext()可以获得一个ServletContext对象,利用这个对象的getAttribute()\/setAttribute()方法可以在整个WEB应该里共享数据,可以实现servlet和jsp之间的数据互传 比如:在servlet中 1 getServletContext.setAttribute("title", "hello world");...

jsp通过servlet传值到另一个jsp页面
3 裤子 99 。。之后,我想点击2号,也就是衣服,看看这个衣服的详细的说明等信息,这个过程你需要获得这个商品代码也就是2号,传到后台,查询数据库,获得信息。这个简单,第一布得时候,你就要把这个商品代码记住,怎么记住,就是显示到页面上,只要是页面上的东西,就可以用js的dom来获得。

jsp怎么实现文章内容的分页显示,文章内容包含HTML标签。
1。取出的分页内容中,html标签不完整(比如<a href=,后面就没了。。。),针对这种情况,我们应该实现一个向前搜索和向后搜索内容以保证html标签完整性的功能。2。有可能出现标签不成对的情况,比如有,没有这种情况,那么这个问题也是我们需要去搜索内容来解决的。或者说做的过分点,我们写一个缺少结...

servlet查询数据库返回一个list对象,放入session中,在JSP页面如何得到l...
servlet中 session.setArribute(key, vlaue);jsp List list = (List)session.getAttribute(key)

点击jsp页面的按钮通过servlet跳转到另一个jsp页面
1、前台: 2、servlet:处理。。。request.setAttribuate("msg","你需要显示的值");this.getServletContext().getRequestDispatcher("跳转的servlet").forward(request, response);3、JSP页面显示 out.print(request.getAttribuate("msg"));求采纳,求给分!

jsp加载时怎么获取后台list集合并遍历
1、首先,需要JSTL-1.2的jar包,自行百度搜索下载。2、将JSTL-1.2的jar包放入web工程的lib文件夹下。3、在需要的遍历List的页面中引入JSTL的核心标签库。4、使用<c:forEach><c:forEach\/>标签遍历List数组。5、【items】中使用EL表达式,来拿到List数组。6、【var】用指定变量名来接收遍历数组的...

JAVA中后台的Servlet程序如何将结果返回给前台的页面
这种一般是用js处理的如果账户不存在 PrintWriter out=response.getWriter();{out .println("alert('用户名不存在');window.history.go(-1)");}\/\/这句会弹出个提示框,然后跳回到原来的页面,就是登陆页面

相似回答