Solved

I am displaying all the list in one page right now using jstl. could you please let me know how to display the same using pagination technique,like 10 items in the list in one page. I am not using sql

Posted on 2009-04-14
7
1,088 Views
Last Modified: 2012-05-06
I am displaying all the list in one page right now using jstl. could you please let me know how to display the same using pagination technique,like 10 items in the list in one page. I am not using sql to retrieve this list. I need to display the page using div tag.

Any code samples or ideas would be appreciated.

thanks
Kalam
0
Comment
Question by:kalam_shaik
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
7 Comments
 
LVL 27

Expert Comment

by:rrz
ID: 24140098
Please show us your JSTL code. Maybe we can work from there.
0
 

Author Comment

by:kalam_shaik
ID: 24140242
Pleease find the snippet of code below used to dispaly the whole list of comments.

<c:if test="${null != blogessay.comments && not empty blogessay.comments}" >
                                                
<h1 class="commentHeader">COMMENTS</h1>
<!-- begin comment (repeat as necessary) -->
      <c:forEach var="comment" items="${blogessay.comments}" varStatus="commentCounter">
            <fmt:parseDate var="dateObj" pattern="yyyy-MM-dd HH:mm:ss.S" value="${comment.lastUpdateDate}" />

<!-- begin comment (repeat as necessary) -->
            <div class="commentDetails">
                  <div class="commenter">
                  <img src="<c:out value="${comment.avatar}" />" alt="" />
                  <div class="label"><c:out value="${comment.userName}" /></div>
            </div>
      <div class="essayComment">
            <span class="bold">POSTED ON:</span> <fmt:formatDate pattern="MMM dd, yyyy hh:mm aaa" value="${dateObj}" /><br />
            <div class="commentActions">
                  <a class="flagit" href="#" onclick='javascript:confirmFlagComment(<c:out value="${comment.ID}" />)'>Flag it</a>
            </div>
      </div>


<div class="commentText">
      <p><c:out value="${comment.commentText}" escapeXml="false" /></p>
</div>
                                          

</div>
<div class="clear"></div>
<c:if test="${!commentCounter.last}" >
</c:if>
<!-- end comment (repeat as necessary) -->
      </c:forEach>
</c:if>

<!-- ***** END comment threads ***** -->
0
 
LVL 11

Expert Comment

by:Manish
ID: 24144934
If you want to write your own, then it is kind of difficult,
but you can use existing tag lib like
http://jsptags.com/tags/navigation/pager/pager-taglib-2.0.html
0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 13

Expert Comment

by:Murali Murugesan
ID: 24145527
Use display tag library its very cool with JSTL.
http://displaytag.sourceforge.net/1.2/

a very simple library to play around with.

-Murali*
0
 
LVL 27

Expert Comment

by:rrz
ID: 24149601
karanw and Murali have made good suggestions.   But, if you just want something simple, then you could use something like the test JSP below here.  If you have any troubles or you need to tweak it, then ask us for help.  
<%@ page import="java.util.*" %>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
<%
   List<String> comments = Arrays.asList("a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z");
%>
<c:set var="comments" scope="session" value="<%=comments%>"/>
<c:set var="totalCount" scope="session" value="<%=comments.size()%>"/>
<c:set var="perPage" scope="session"  value="4"/>
<c:forEach var="boundaryStart" begin="0" end="${totalCount - 1}" step="${perPage}">
         <a href="?start=${boundaryStart}">[${boundaryStart} - ${boundaryStart + perPage - 1}]</a>
</c:forEach>
<c:if test="${null != comments && not empty comments}" >                                                
<h1 class="commentHeader">COMMENTS</h1>
   <c:forEach var="comment" items="${comments}" varStatus="commentCounter"
                            begin="${param.start}" end="${param.start + perPage - 1}">
       <div class="commentDetails">
                  <div class="commenter">
                          <div class="label">${comment}</div>
                  </div>
         <div class="essayComment">
            <span class="bold">POSTED ON:</span> <fmt:formatDate pattern="MMM dd, yyyy hh:mm aaa" value="${dateObj}" /><br />
            <div class="commentActions">
                  <a class="flagit" href="#" onclick='javascript:confirmFlagComment(${comment})'>Flag it</a>
            </div>
         </div>
       </div>
   </c:forEach>
</c:if>

Open in new window

0
 

Author Comment

by:kalam_shaik
ID: 24150329
Thanks Karan and Murali. The above code snippet is sufficient for my requirement, but I am trying to make some modifications to the code that so that I can get the list as 1-10 and the button next (>) to display the next 10 items and button to go to previous(<). Please let me know if you have any immediate thoughts to do some thing like this.

just some thing like this 1-10  of 80  : »

thanks,
Kalam
0
 
LVL 27

Accepted Solution

by:
rrz earned 500 total points
ID: 24154588
Here is what I did tonight. If you need more help, then tell us. Maybe I will have more time tomorrow.  
<%@ page import="java.util.*" %>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
<%
   List<String> comments = Arrays.asList("a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z");
%>
<c:set var="comments" scope="session" value="<%=comments%>"/>
<c:set var="totalCount" scope="session" value="<%=comments.size()%>"/>
<c:set var="perPage" scope="session"  value="10"/>
<c:set var="pageStart" value="${param.start}"/>
<c:if test="${empty pageStart or pageStart < 0}">
       <c:set var="pageStart" value="0"/>
</c:if>
<c:if test="${totalCount < pageStart}">
       <c:set var="pageStart" value="${pageStart - 10}"/>
</c:if>
        <a href="?start=${pageStart - 10}"><<</a>${pageStart + 1} - ${pageStart + 10} <a href="?start=${pageStart + 10}">>></a>
<c:if test="${null != comments && not empty comments}" >                                                
<h1 class="commentHeader">COMMENTS</h1>
   <c:forEach var="comment" items="${comments}" varStatus="commentCounter"
                            begin="${pageStart}" end="${pageStart + perPage - 1}">
       <div class="commentDetails">
                  <div class="commenter">
                          <div class="label">${comment}</div>
                  </div>
         <div class="essayComment">
            <span class="bold">POSTED ON:</span> <fmt:formatDate pattern="MMM dd, yyyy hh:mm aaa" value="${dateObj}" /><br />
            <div class="commentActions">
                  <a class="flagit" href="#" onclick='javascript:confirmFlagComment(${comment})'>Flag it</a>
            </div>
         </div>
       </div>
   </c:forEach>
</c:if>

Open in new window

0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Fisheye tool 2 122
struts exact match support 3 59
withoutString  challenge 40 216
How can I   ajax html table  rows? 20 80
Facebook has became the #1 social media platform. People share many funny videos there, yet you don't know how to download them? Now you can download Videos from Facebook in just 3 simple steps.
While it may be true that the internet is a place of possibilities, it is also a hostile environment lurking with many dangers. By clicking on the wrong link, trusting the wrong person or using a weak password, you are virtually inviting hackers to …
The Email Laundry PDF encryption service allows companies to send confidential encrypted  emails to anybody. The PDF document can also contain attachments that are embedded in the encrypted PDF. The password is randomly generated by The Email Laundr…
Exchange organizations may use the Journaling Agent of the Transport Service to archive messages going through Exchange. However, if the Transport Service is integrated with some email content management application (such as an antispam), the admini…

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question