Bootstrap實現翻頁效果

來源:互聯網
上載者:User
Bootstrap,來自 Twitter,是目前很受歡迎的前端架構。Bootstrap 是基於 HTML、CSS、JavaScript 的,它簡潔靈活,使得 Web 開發更加快捷。本文主要為大家詳細介紹了Bootstrap實現翻頁效果,具有一定的參考價值,感興趣的小夥伴們可以參考一下。

優點:

支援局部重新整理;
只要是列表,都可以載入該組件;
支援動態資料綁定;
當然還有絕對的簡單實用。

最後一頁時:

最開始一頁時:

實現

①、翻頁組件的布局


<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><%@ include file="/components/common/taglib.jsp"%><c:if test="${urlParas == null}"> <c:set var="urlParas" value="" /></c:if><c:if test="${(totalPage > 0) && (currentPage <= totalPage)}"> <c:set var="startPage" value="${currentPage - 4}" /> <c:if test="${startPage < 1}"> <c:set var="startPage" value="1" /> </c:if> <c:set var="endPage" value="${currentPage + 4}" /> <c:if test="${endPage > totalPage}"> <c:set var="endPage" value="totalPage" /> </c:if> <nav> <ul class="pager">  <c:if test="${currentPage <= 8}">  <c:set var="startPage" value="1" />  </c:if>  <c:if test="${(totalPage - currentPage) < 8}">  <c:set var="endPage" value="${totalPage}" />  </c:if>  <c:choose>  <c:when test="${currentPage == 1}">   <li class="previous disabled"><a>    <span aria-hidden="true">←</span>    前一頁   </a></li>  </c:when>  <c:otherwise>   <li class="previous"><a href="javascript:;" pageNum="${currentPage - 1}" rel="${rel}" urlParas="${urlParas}">    <span aria-hidden="true">←</span>    前一頁   </a></li>  </c:otherwise>  </c:choose>  <c:choose>  <c:when test="${currentPage == totalPage}">   <li class="next disabled"><a>    後一頁    <span aria-hidden="true">→</span>   </a></li>  </c:when>  <c:otherwise>   <li class="next"><a href="javascript:;" pageNum="${currentPage + 1}" rel="${rel}" urlParas="${urlParas}">    後一頁    <span aria-hidden="true">→</span>   </a></li>  </c:otherwise>  </c:choose> </ul> </nav></c:if>


  • pageNum:第幾頁

  • rel:要重新整理哪一個p的id

  • urlParas:其他參數

②、調用翻頁組件


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><%@ include file="/components/common/taglib.jsp"%><c:set var="currentPage" value="${dealPage.pageNumber}" /><c:set var="totalPage" value="${dealPage.totalPage}" /><c:set var="rel" value="deal_items" /><c:set var="urlParas" value="" /><%@ include file="/components/common/paginate.jsp"%>


  • currentPage:頁數

  • totalPage:總頁數

  • rel:局部重新整理p的id

  • urlParas:其他參數,暫無

③、翻頁事件


$(function() {// 翻頁組件 $("ul[class=pager] li:not(.disabled) > a", $p).each(function() { $(this).click(function(event) {  var $this = $(this);  YUNM.debug($this.attr("pageNum") + "、" + $this.attr("rel") + "、" + $this.attr("urlParas"));  var pageNum = $this.attr("pageNum");  // 準備翻頁事件  if (pageNum && pageNum.isPositiveInteger()) {  yunmPageBreak({   rel : $this.attr("rel"),   data : {   pageNum : pageNum,   urlParas : $this.attr("urlParas")   }  });  }  event.preventDefault();  return false; }); });});


  • 頁面載入完成後,擷取翻頁的a標籤,為其載入翻頁功能。

  • 設定pageNum,這個肯定必須傳遞

  • 擷取局部重新整理p,這個地方以後有待改善,通過id擷取好像不太好。

  • 傳遞額外參數urlParas

  • 最後阻止a標籤既有事件。


/** * 翻頁 *  * @param options */function yunmPageBreak(options) { var op = $.extend({ rel : "", data : {  pageNum : "",  numPerPage : "",  orderField : "",  orderDirection : "",  urlParas : "" }, callback : null }, options); var $panel = $("#" + op.rel); if (op.rel) { var dataId = $panel.attr("data"); var url = $panel.attr("url"); // 設定p上的其他參數 if (dataId) {  if (dataId.indexOf(",") != -1) {  $.each(dataId.split(","), function(index, id) {   if ($("#" + id) && $("#" + id).val()) {   url = addMoreParamForUrl(url, id, $("#" + id).val());   }  });  } else {  if ($("#" + dataId) && $("#" + dataId).val()) {   url = addMoreParamForUrl(url, dataId, $("#" + dataId).val());  }  } } // 局部重新整理 $panel.ajaxUrl({  type : "POST",  url : url,  data : op.data,  callback : function(response) {  if ($.isFunction(op.callback))   op.callback(response);  } }); }}


  • 這串代碼也很好懂,擷取ajax請求的url

  • 擷取ajax請求的參數data

  • 至於ajaxUrl方法,請參照我的再談ajax局部重新整理,我覺得這樣局部重新整理還是很實用的。

到這,前台的內容都OK了,接下來需要什麼呢?自然是jfinal端的資料擷取。

④、分頁資料擷取


public Page<Deals> paginateCreateDealsByUid(int pageNumber, int pageSize, Long uid) { Page<Deals> deals = paginate(pageNumber, pageSize, "select y.*",  "from ym_dels y where y.uid = ? order by y.opertime desc", uid); return deals;}


  • jfinal自然已經提供了很好的翻頁功能paginate方法。

  • 就只需要把對應的資料返回就可以了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.