How to Implement pagination in JSP
1. mysql limit keyword (DAO)
Select * from tablename limit startPoint, numberPerPage;
Tablename is the name of the table to be displayed by page;
StartPoint is the starting position-1;
NumberPerPage is the number of entries displayed on a page.
Example: select * from comment limit 20, 5;
Then 21 ~ is extracted from the comment table ~ Comment on the 25 th:
2. jQuery load function (page JS)
The MySQL limit keyword can be used to extract records of a certain range (n, n + m]. That is to say, two parameters are required to determine the content displayed on a page, that is, "page x" and the number of entries displayed on each page.
The number of entries displayed on each page can be set in the program or by the user. However, the "page x" parameter must be provided by the user. When a user clicks the page number, next page/Previous Page button, or jumps to a page, the "page x" parameter needs to be sent to the server for record extraction.
Function goToPage (page ){
$ ('Body'). load ("getComments. do? Page = "+ page );
}
Alternatively, if both parameters are specified by the user, the function can be written:
Function goToPage (page, numberPerPage ){
$ ('Body'). load ("getComments. do? Page = "+ page +" & npp = "+ numberPerPage );
}
3. servlet receives parameters and organizes the content (servlet File)
By accepting the page and npp parameters in the request object sent from the jsp page, the servlet learns the page X you want to browse and the number of records displayed on the page.
Int page = Integer. parseInt (req. getParameter ("page "));
4. servlet computing page list
Generally, 10 pages are displayed at a time, that is, if the page number is 52nd, the available page lists are 50, 51, and 52... Until 60.
The calculation method is as follows: assume that the current page is on page x, the starting value is x/10*10, provided that x> 10. The written code is:
Int start = 1;
If (page> = 10 ){
Start = page/10*10;
}
There are two special cases:
① A total of less than 10 pages
② The number of pages is not an integer multiple of 10
In this case, the page number list is smaller than 10, and it is easy to process. Just add the if condition to judge. The rough code is as follows:
Int total = sm. getCommentCount ();
Int totalPage = total/itemsPerPage;
If (total % itemsPerPage! = 0 ){
TotalPage + = 1;
}
Vector <Integer> pageArr = new Vector <Integer> ();
Int start = 1;
If (page> = 10 ){
Start = page/10*10;
}
Int num = start;
While (! (Num> totalPage | num> start + 10 )){
PageArr. add (new Integer (num ));
++ Num;
}
5. display the page number list on the jsp page
4. We get a calculated page number list pageArr, which indicates which pages should be displayed for the current page for users to click directly. Add the pageArr list in the servlet to the response object and the page (current page number) and totalPage (maximum page number) to help us make some judgments.
<! --Previous Page button -->
<Div id = "pageControl">
<C: choose>
<C: when test = "$ {page! = 1} ">
<A href = "checkComments. do? Page =$ {page-1} "> <in put type =" button "name =" lastPage "value =" Previous page "/> </a>
</C: when>
<C: otherwise>
<In put type = "button" disabled = "true" name = "lastPage" value = "Previous Page"/> <! --For the dimmed button -->
</C: otherwise>
</C: choose>
<! --Page list -->
<C: forEach items = "$ {pageList}" var = "item">
<C: choose>
<C: when test = "$ {item = page}">
<A href = "checkComments. do? Page =$ {item} "class =" currentPage ">$ {item} </a>
</C: when>
<C: otherwise>
<A href = "checkComments. do? Page =$ {item} ">$ {item} </a>
</C: otherwise>
</C: choose>
</C: forEach>
<! --Next page button -->
<C: choose>
<C: when test = "$ {page! = TotalPages} ">
<A href = "checkComments. do? Page =$ {page + 1} ">
<In put type = "button" name = "nextPage" value = "next page"/>
</A>
</C: when>
<C: otherwise>
<In put type = "button" disabled = true name = "nextPage" value = "next page"/> <! --For the dimmed button -->
</C: otherwise>
</C: choose>
<! --Jump directly -->
$ {TotalPages} pages in total-to the <in put type = "text" id = "jumpTo"/> page <in put type = "button" value = "jump" on click = "jumpTo ($ {totalPages }) "/>
</Div>
Js functions used
Function jumpTo (maxPage ){
Var page = $ ("# jumpTo"). val ();
If (page> maxPage | page <1 ){
Alert ("sorry, this page cannot be reached ")
} Else {
$ ('Body'). load ('checkcomments. do? Page = '+ page );
}
}
6. CSS Enhancement
To highlight the current page number, we made a special judgment in the above Code:
<C: when test = "$ {item = page}">
<A href = "checkComments. do? Page =$ {item} "class =" currentPage ">$ {item} </a>
</C: when>
In this way, the current page number will be marked as the currentPage class, so that you can emphasize it in the CSS file. For example:
. CurrentPage {
Font-weight: bold;
Color: # ff9a00;
}
Or set the width of the following jump page input box
# JumpTo {
Width: 20px;
}
In this way, the current page will be marked in bold, orange:
7. Improvement
Although it is convenient to use the method of a label for Link, it may not feel bad if there is an underscore. You can use css to remove it, or add some changes to the hover.
# PageControl {
Text-decoration: none;
}