page類
員工經過長期磨合與沉淀,具備了協作精神,得以通過團隊的力量開發出優質的產品。創新互聯建站堅持“專注、創新、易用”的產品理念,因為“專注所以專業、創新互聯網站所以易用所以簡單”。公司專注于為企業提供成都網站建設、成都網站設計、微信公眾號開發、電商網站開發,小程序制作,軟件定制開發等一站式互聯網企業服務。
public class PageModel {
private int totalCount = 0;// 總記錄數
private int pageCount;// 總頁數
private int pageSize = 10;// 每頁顯示記錄數
private int page = 1;// 當前頁
private int num = 5;// 當前頁之前和之后顯示的頁數個數 如:假設當前頁是 6 共有11頁 那么 顯示分頁條會顯示 1 2 3 4
// 5 [6] 7 8 9 10 11
@SuppressWarnings("unchecked")
private List items = new ArrayList();// 當前頁記錄內容集合
private int prev;// 前一頁
private int next;// 后一頁
private int last;// 最后一頁
private ListInteger prevPages;// 得到前num頁的數據集合
private ListInteger nextPages;// 得到后num頁的數據集合
/**
* 計算總頁數
*
* @param totalCount
*/
public void setTotalCount(int totalCount) {
if (totalCount 0) {
this.totalCount = totalCount;
this.pageCount = (totalCount + pageSize - 1) / pageSize;
}
}
/**
* 判斷是否有前一頁
*
* @return boolean
*/
public boolean getIsPrev() {
if (page 1) {
return true;
}
return false;
}
/**
* 獲取前一頁
*
* @return int
*/
public int getPrev() {
if (getIsPrev()) {
return page - 1;
} else {
return page;
}
}
/**
* 判斷是否有后一頁
*
* @return boolean
*/
public boolean getIsNext() {
if (page pageCount) {
return true;
}
return false;
}
/**
* 獲取后一頁
*
* @return int
*/
public int getNext() {
if (getIsNext()) {
return page + 1;
}
return getPageCount();
}
/**
* 獲取最后一頁
*
* @return int
*/
public int getLast() {
return pageCount;
}
/**
* 當前頁的前num條頁 假設當前頁是 6 共有11頁 如:1 2 3 4 5
*
* @return ListInteger
*/
public ListInteger getPrevPages() {
ListInteger list = new ArrayListInteger();
int _frontStart = 1;
if (page num) {
_frontStart = page - num;
} else if (page = num) {
_frontStart = 1;
}
for (int i = _frontStart; i page; i++) {
list.add(i);
}
return list;
}
/**
* 當前頁的后num條頁 假設當前頁是 6 共有11頁 如:7 8 9 10 11
*
* @return ListInteger
*/
public ListInteger getNextPages() {
ListInteger list = new ArrayListInteger();
int _endCount = num;
if (num pageCount (page + num) pageCount) {
_endCount = page + _endCount;
} else if ((page + num) = pageCount) {
_endCount = pageCount;
}
for (int i = page + 1; i = _endCount; i++) {
list.add(i);
}
return list;
}
/**
* 獲取每頁顯示記錄數
*
* @return int
*/
public int getPageSize() {
return pageSize;
}
/**
* 設置每頁顯示記錄數
*
* @param pageSize
*/
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
/**
* 得到當前頁數
*
* @return int
*/
public int getPage() {
return page;
}
/**
* 設置當前頁數
*
* @param page
*/
public void setPage(int page) {
this.page = page;
}
/**
* 獲取當前頁之前或之后顯示的頁數個數
*
* @return int
*/
public int getNum() {
return num;
}
/**
* 設置當前頁之前或之后顯示的頁數個數
*
* @param num
*/
public void setNum(int num) {
this.num = num;
}
/**
* 獲取當前頁記錄內容集合
*
* @return List
*/
@SuppressWarnings("unchecked")
public List getItems() {
return items;
}
/**
* 設置當前頁記錄內容集合
*
* @param items
*/
@SuppressWarnings("unchecked")
public void setItems(List items) {
this.items = items;
}
/**
* 獲取總記錄數
*
* @return int
*/
public int getTotalCount() {
return totalCount;
}
/**
* 得到總頁數
*
* @return int
*/
public int getPageCount() {
return pageCount;
}
}
action代碼:
PageModel pageModel = new PageModel();
// 獲得當前頁
if (page != 0) {
pageModel.setPage(page);
}
pageModel.setPageSize(10);// 設置頁面顯示最大 值
pageModel.setTotalCount(baseDAO.listAll("from Art where arttype.id=10 and mark=0 order by id desc")); // 數據總條數
pageModel.setNum(5); // 設置當前頁的前后距離,/**前后各顯示5頁**/
// 通過當前頁和
ListArt aboutList = baseDAO.listAll("from Art where arttype.id=10 and mark=0 order by id desc", pageModel.getPage(),pageModel.getPageSize());
pageModel.setItems(aboutList);
request.setAttribute("count", aboutList.size());// 放置在request中
request.setAttribute("pageModel", pageModel);
request.setAttribute("page", pageModel.getPage());
jsp代碼
c:forEach var = "i" items="${requestScope.pageModel.items}" varStatus="items"
li/li
/c:forEach
div class="badoo"span class="disabled"第${pageModel.page}頁/共${pageModel.pageCount}頁/span a href="${pageuri}page=1"首頁/a
c:if test="${pageModel.page1}"
a href="${pageuri}page=${pageModel.prev}"上一頁/a
/c:if
c:forEach var="pre" items="${pageModel.prevPages }"
a href="${pageuri}page=${pre }"${pre}/a
/c:forEach
span class="current"${pageModel.page }/span
c:forEach var="next" items="${pageModel.nextPages }"
a href="${pageuri}page=${next }"${next}/a
/c:forEach
c:if test="${pageModel.pagepageModel.last}"
a href="${pageuri}page=${pageModel.next}"下一頁/a
/c:if
a href="${pageuri}page=${pageModel.last}"尾頁/a/div
如有不懂可以找我QQ聊
以下是最簡單的分頁(一個方法搞定):
首先是方法:
//用于按照頁數和每頁顯示的記錄數進行圖書查詢
public List getBookList(int page,int pageSize)throws Exception{
List list=new ArrayList();
Connection conn=this.getConn();
String sql="select top "+page+" * from bookInfo " +
"where bookId not in" +
"(select top "+((pageSize-1)*page)+" bookId from bookInfo)";
PreparedStatement pstmt=conn.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();
while(rs.next()){
//每條數據對應一個實體類
BookInfo book=new BookInfo();
book.setBookId(rs.getInt("bookId"));
book.setBookName(rs.getString("bookName"));
book.setBookType(rs.getString("bookType"));
book.setBookStatus(rs.getString("bookStatus"));
list.add(book);
}
this.closeAll(conn, pstmt, rs);
return list;
}
2:JSP頁面代碼:
%@ page language="java" import="java.util.*,entity.*,operator.*" pageEncoding="gbk"%
html
head
/head
body
table border="1"
tr
td width="150"圖書名稱/td
td width="100"類別/td
td width="100"狀態/td
/tr
%
request.setCharacterEncoding("gbk");
int pageNum=1;
String pageStr=request.getParameter("pageNum");
if(pageStr==null){
pageNum=1;
}else{
pageNum=Integer.parseInt(pageStr);
}
Operator o=new Operator();
List list=o.getBookList(6,pageNum);
for(int i=0;ilist.size();i++){
BookInfo book=(BookInfo)list.get(i);
%
tr
td%=book.getBookName() %/td
td%=book.getBookType() %/td
td%=book.getBookStatus() %/td
/tr
%
}
%
tr
td colspan="3"a href="infoList.jsp?pageNum=%=pageNum==1?pageNum:pageNum-1%"上一頁/a ||
a href="infoList.jsp?pageNum=%=list.size()6?pageNum:pageNum+1 %"下一頁/a/td//二元運算符,相當于if判斷 上一頁時如果當前頁=1為true,就是當前頁,否則還可以減1
//下一頁如果當前頁的size小于你的每一頁設置的條數為true,那么就是是當前頁,否則就+1;
/tr
/table
/body
/html
CREATE PROCEDURE [up_ARCH_DCFJ_Paged]
@pagesize int, --每頁顯示的記錄數
@pageindex int, --當前頁索引,最小值為1
@RecordCount int output --總記錄數,0時不統計結果記錄
AS
SET NOCOUNT ON
DECLARE @indextable TABLE(rowid INT IDENTITY(1,1),nid INT)
INSERT INTO @indextable(nid) --將符合的記錄插入到臨時表中
SELECT [FileID]
FROM [ARCH_DCFJ]
ORDER BY [FileID] DESC
IF(@RecordCount0)
BEGIN
SELECT @RecordCount= Count(1) FROM @indextable
END
DECLARE @PageLowerBound INT
DECLARE @PageUpperBound INT
SET @PageLowerBound=(@pageindex-1)*@pagesize
SET @PageUpperBound=@PageLowerBound+@pagesize
SET ROWCOUNT @PageUpperBound--最多執行行數 若下面還有超過此值的行數,請注釋此行
SELECT a.*
FROM [ARCH_DCFJ] a,@indextable t
WHERE a.[FileID]=t.nid and t.rowid@PageLowerBound and t.rowid=@PageUpperBound
ORDER BY t.rowid
SET NOCOUNT OFF
GO
可以把要從數據庫里查詢出的數據條數用sql語句寫出來。
int rowBegin=0;
if(page1)
rowBegin=10*(page-1); 10就是你要顯示的行數
String sql="select top 10 * from table where id not in(select top+"+rowBegin+" id from table )";
按下頁時直接傳參就可以了
網頁題目:java分頁jsp代碼 jsp實現分頁
網址分享:http://m.newbst.com/article24/dogodce.html
成都網站建設公司_創新互聯,為您提供網站內鏈、網站營銷、云服務器、域名注冊、虛擬主機、商城網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯