欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Bootstrap實現(xiàn)翻頁效果

 更新時間:2017年11月27日 15:51:56   作者:沉默王二  
這篇文章主要為大家詳細介紹了Bootstrap實現(xiàn)翻頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

Bootstrap之翻頁。

優(yōu)點:

支持局部刷新;
只要是列表,都可以加載該組件;
支持動態(tài)數(shù)據(jù)綁定;
當然還有絕對的簡單實用。

效果圖

最后一頁時:

這里寫圖片描述

最開始一頁時:

實現(xiàn)

①、翻頁組件的布局

<%@ 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">&larr;</span>
    前一頁
   </a></li>
  </c:when>
  <c:otherwise>
   <li class="previous"><a href="javascript:;" pageNum="${currentPage - 1}" rel="${rel}" urlParas="${urlParas}">
    <span aria-hidden="true">&larr;</span>
    前一頁
   </a></li>
  </c:otherwise>
  </c:choose>

  <c:choose>
  <c:when test="${currentPage == totalPage}">
   <li class="next disabled"><a>
    后一頁
    <span aria-hidden="true">&rarr;</span>
   </a></li>
  </c:when>
  <c:otherwise>
   <li class="next"><a href="javascript:;" pageNum="${currentPage + 1}" rel="${rel}" urlParas="${urlParas}">
    后一頁
    <span aria-hidden="true">&rarr;</span>
   </a></li>
  </c:otherwise>
  </c:choose>

 </ul>
 </nav>
</c:if>
  • pageNum:第幾頁
  • rel:要刷新哪一個div的id
  • urlParas:其他參數(shù)

②、調用翻頁組件

<!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:頁數(shù)
  • totalPage:總頁數(shù)
  • rel:局部刷新div的id
  • urlParas:其他參數(shù),暫無

③、翻頁事件

$(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,這個肯定必須傳遞
  • 獲取局部刷新div,這個地方以后有待改善,通過id獲取好像不太好。
  • 傳遞額外參數(shù)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");

 // 設置div上的其他參數(shù)
 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請求的參數(shù)data
  • 至于ajaxUrl方法,請參照我的再談ajax局部刷新,我覺得這樣局部刷新還是很實用的。

到這,前臺的內容都OK了,接下來需要什么呢?自然是jfinal端的數(shù)據(jù)獲取。

④、分頁數(shù)據(jù)獲取

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自然已經(jīng)提供了很好的翻頁功能paginate方法。
  • 就只需要把對應的數(shù)據(jù)返回就可以了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 關于Aptana Studio生成自動備份文件的解決辦法

    關于Aptana Studio生成自動備份文件的解決辦法

    關于Aptana Studio生成自動備份文件的解決辦法
    2009-12-12
  • JavaScript requestAnimationFrame動畫詳解

    JavaScript requestAnimationFrame動畫詳解

    這篇文章主要為大家詳細介紹了JavaScript requestAnimationFrame動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Firefox和IE瀏覽器兼容JS腳本寫法小結

    Firefox和IE瀏覽器兼容JS腳本寫法小結

    window.event兼容腳本 1.2.屏蔽Form提交事件 3.獲取事件源 4.添加事件兼容寫法 5.Firefox注冊innerText寫法 6.長度 7.父控件下的子控件 8.XmlHttp
    2008-07-07
  • JavaScript函數(shù)式編程實現(xiàn)介紹

    JavaScript函數(shù)式編程實現(xiàn)介紹

    函數(shù)式編程是一種編程范式,將整個程序都由函數(shù)調用以及函數(shù)組合構成。 可以看成一條流水線,數(shù)據(jù)可以不斷地從一個函數(shù)的輸出流入另一個函數(shù)的輸入,最后輸出結果
    2022-09-09
  • javascript拖曳互換div的位置實現(xiàn)示例

    javascript拖曳互換div的位置實現(xiàn)示例

    一個div拖動互換位置的demo,還有很大優(yōu)化的空間,利用dom元素的dragstart/ondragover/ondrop事件完成,感興趣的可以了解一下
    2021-06-06
  • JS跨域代碼片段

    JS跨域代碼片段

    js跨域我用的比較多的就是jsonp和程序代理。但是jsonp只能用get,而且是js異步調用,有時候不能滿足項目要求
    2012-08-08
  • 深入理解JavaScript 中的執(zhí)行上下文和執(zhí)行棧

    深入理解JavaScript 中的執(zhí)行上下文和執(zhí)行棧

    這篇文章主要介紹了JavaScript 中的執(zhí)行上下文和執(zhí)行棧的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10
  • JS解析url查詢參數(shù)的簡單代碼

    JS解析url查詢參數(shù)的簡單代碼

    本文通過簡單代碼給大家介紹了js解析url查詢參數(shù)的方法,然后在文章下面給大家介紹了js獲取url參數(shù)值的兩種方式 ,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-08-08
  • leaflet加載geojson疊加顯示功能代碼

    leaflet加載geojson疊加顯示功能代碼

    這篇文章主要介紹了leaflet加載geojson疊加顯示功能代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • 微信分享調用jssdk實例

    微信分享調用jssdk實例

    這篇文章主要為大家詳細介紹了微信分享調用jssdk實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評論