对数据进行分页显示到table中的实现方法
程序员文章站
2024-03-11 20:39:43
我最先用jframe编程的时候写的比较简单,只是先查询到所有记录,再根据当前页码筛选出当前页的记录,返回的小集合可以直接显示到table上。
import j...
我最先用jframe编程的时候写的比较简单,只是先查询到所有记录,再根据当前页码筛选出当前页的记录,返回的小集合可以直接显示到table上。
import java.util.arraylist; import java.util.list; import com.yu.entity.user; public class pagecontroller { private list<user> biglist=new arraylist<user>(); //大集合,从外界获取 private list<user> smalllist=new arraylist<user>(); //小集合,返回给调用它的类 private static int curentpageindex=1; //当前页码 private int countperpage=10; //每页显示条数 private int pagecount; //总页数 private int recordcount; //总记录条数 //初始化块,调用类的时候首先自动加载 { //调用查询数据库的方法,返回一个list this.biglist = new utils().query(); //计算总页数 if (biglist.size()%countperpage==0) { this.pagecount=biglist.size()/countperpage; } else { this.pagecount=(biglist.size()/countperpage)+1; } } public pagecontroller() { } //传入指定页码的构造函数,参看第几页。 public pagecontroller(int curentpageindex){ this.curentpageindex=curentpageindex; } //确切的获取当前页的记录,返回一个list列表 public list<user> setcurentpageindex() { return select(); } //下一页 public list<user> nextpage() { if (curentpageindex < pagecount ) { curentpageindex++; system.out.println("当前页:"+curentpageindex); } return select(); } //上一页 public list<user> previouspage() { if (curentpageindex > 1) { curentpageindex--; system.out.println("当前页:"+curentpageindex); } return select(); } //此方法供以上方法调用,根据当前页,筛选记录 public list<user> select(){ recordcount=biglist.size(); for(int i=(curentpageindex-1)*countperpage; i<curentpageindex*countperpage&&i<recordcount; i++){ smalllist.add(biglist.get(i)); } return smalllist; } }
下面是写在jframe中的内容,调用分页方法。
//查询上一页 private void jbutton8actionperformed(java.awt.event.actionevent evt) { list<user> newlist = new pagecontroller().previouspage(); viewall(newlist); } //返回第一页的记录 private void jbutton10actionperformed(java.awt.event.actionevent evt) { list<user> newlist = new pagecontroller(1).setcurentpageindex(); viewall(newlist); } //查询下一页 private void jbutton9actionperformed(java.awt.event.actionevent evt) { list<user> newlist = new pagecontroller().nextpage(); viewall(newlist); } //显示list中的用户 public void viewall(list<user> list) { object[][] objects = new object[(list.size())][]; for (int i = 0; i < objects.length; i++) { objects[i] = new object[3]; objects[i][0] = i + 1; objects[i][1] = list.get(i).getuserid(); objects[i][2] = list.get(i).gettruename(); } jtable1.setmodel(new javax.swing.table.defaulttablemodel(objects, new string[] { "行号", "工号", "姓名" })); }
以上所述是小编给大家介绍的对数据进行分页显示到table中的实现方法,希望对大家有所帮助
上一篇: PHP SFTP实现上传下载功能