最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當前位置: 首頁 - 科技 - 知識百科 - 正文

Bootstrap實現翻頁效果

來源:懂視網 責編:小采 時間:2020-11-27 22:24:52
文檔

Bootstrap實現翻頁效果

Bootstrap實現翻頁效果:Bootstrap之翻頁。 優點: 支持局部刷新; 只要是列表,都可以加載該組件; 支持動態數據綁定; 當然還有絕對的簡單實用。 效果圖 最后一頁時: 最開始一頁時: 實現 ①、翻頁組件的布局 <%@ page language=java contentType=
推薦度:
導讀Bootstrap實現翻頁效果:Bootstrap之翻頁。 優點: 支持局部刷新; 只要是列表,都可以加載該組件; 支持動態數據綁定; 當然還有絕對的簡單實用。 效果圖 最后一頁時: 最開始一頁時: 實現 ①、翻頁組件的布局 <%@ page language=java contentType=

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:要刷新哪一個div的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:局部刷新div的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,這個肯定必須傳遞
  • 獲取局部刷新div,這個地方以后有待改善,通過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");
    
     // 設置div上的其他參數
     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方法。
  • 就只需要把對應的數據返回就可以了。
  • 聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    Bootstrap實現翻頁效果

    Bootstrap實現翻頁效果:Bootstrap之翻頁。 優點: 支持局部刷新; 只要是列表,都可以加載該組件; 支持動態數據綁定; 當然還有絕對的簡單實用。 效果圖 最后一頁時: 最開始一頁時: 實現 ①、翻頁組件的布局 <%@ page language=java contentType=
    推薦度:
    標簽: 實現 效果 分頁
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    国产精品久久久久精品…-国产精品可乐视频最新-亚洲欧美重口味在线-欧美va免费在线观看