java代写/算法代写:java进行分页class设计

java代写/算法代写:这是一个典型的java软件设计作业,主要通过java进行分页class设计
paginator(分页访问)、page(单页内容访问)功能

1、创建列表:makeList;

2、填充列表内容:lst.append();

3、获取列表的分页对象:p=lst.paginate(n);(p就是Paginator对象,比如整个列表100条记录、分页对象就是把列表按每n个记录为一页,这样分为x页,x=100/n按上限取整)

4、对分页对象,可获得每页的对象:p1=p.next();(p1就是Page对象)

5、对每页的对象,可按顺序获得这页里的n条记录:record=p1.next();(record就是其中一条记录)

先不管具体针对哪个List,只说实现分页的思路(不止一种思路,这里先写一种):

1、Paginator类,至少包括的变量:每页记录数perPage(就是lst.paginate(n)里传入的n)、总页数totalPages、当前页码currPage;

1.1、totalPages就是根据总记录数和perPage计算得出,比如:记录总数一共是10条,n=3,说明一共有10条记录、每页3条,那么页数totalPages就是4;

1.2、currPage就是记录当前页码的变量,初始为0,每次调用next()时自增1,调用previous()时自减1;注意:按我的方法,这个变量有效值从1开始(也可以把它变成从0开始的,前后都调整一下);

1.3、hasNext()方法,要根据currPage和totalPages判断是否有下一页,比如:如果currPage小于totalPages,则说明还有下一页,返回true,否则返回false;

1.4、next()方法,首先currPage++,然后返回一个Page对象(下面会写),注意如果不满足时应该抛出异常;

1.5、hasPrevious()方法,根据currPage判断是否还有前一页,比如:如果currPage>1,则返回true,否则返回false;

1.6、previous()方法,跟next函数相反;

1.7、nextIndex()方法,返回currPage;

1.8、previousIndex()方法,返回currPage-1;

2、Page类,至少包括的变量:本页的记录起始编号start、本页的记录末尾编号end、当前记录编号curr;

2.1、初始化时,Paginator应该传入的start、end,即:Paginator创建一个Page时,需要指定这个Page是从第几条记录开始(start)、共含几条记录(也就是end=start+n);curr变量初始化可以是start;

2.2、初始化时还应该判断,end如果已经超过了整个List的最后一条记录,则应该改为最后一条记录编号;比如,整个列表一共10条记录(编号分别时0~9)、每页3条,在初始化最后一个Page时,start从9开始,end=9+3=12,此时end已经大于列表最后一个编号9了,所以end应该改为9,也就是说,这个Page里start=9、end也等于9;

2.3、hasNext()方法,如果curr>end了,则返回false,否则返回true;

2.4、next()方法,返回curr编号对应的记录,并将curr++;

Leave a Reply

Your email address will not be published. Required fields are marked *