Bootstrap實(shí)現(xiàn)翻頁(yè)效果
Bootstrap之翻頁(yè)。
優(yōu)點(diǎn):
支持局部刷新;
只要是列表,都可以加載該組件;
支持動(dòng)態(tài)數(shù)據(jù)綁定;
當(dāng)然還有絕對(duì)的簡(jiǎn)單實(shí)用。
效果圖
最后一頁(yè)時(shí):
最開(kāi)始一頁(yè)時(shí):
實(shí)現(xiàn)
①、翻頁(yè)組件的布局
<%@ 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> 前一頁(yè) </a></li> </c:when> <c:otherwise> <li class="previous"><a href="javascript:;" pageNum="${currentPage - 1}" rel="${rel}" urlParas="${urlParas}"> <span aria-hidden="true">←</span> 前一頁(yè) </a></li> </c:otherwise> </c:choose> <c:choose> <c:when test="${currentPage == totalPage}"> <li class="next disabled"><a> 后一頁(yè) <span aria-hidden="true">→</span> </a></li> </c:when> <c:otherwise> <li class="next"><a href="javascript:;" pageNum="${currentPage + 1}" rel="${rel}" urlParas="${urlParas}"> 后一頁(yè) <span aria-hidden="true">→</span> </a></li> </c:otherwise> </c:choose> </ul> </nav> </c:if>
- pageNum:第幾頁(yè)
- rel:要刷新哪一個(gè)div的id
- urlParas:其他參數(shù)
②、調(diào)用翻頁(yè)組件
<!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:頁(yè)數(shù)
- totalPage:總頁(yè)數(shù)
- rel:局部刷新div的id
- urlParas:其他參數(shù),暫無(wú)
③、翻頁(yè)事件
$(function() { // 翻頁(yè)組件 $("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"); // 準(zhǔn)備翻頁(yè)事件 if (pageNum && pageNum.isPositiveInteger()) { yunmPageBreak({ rel : $this.attr("rel"), data : { pageNum : pageNum, urlParas : $this.attr("urlParas") } }); } event.preventDefault(); return false; }); }); });
- 頁(yè)面加載完成后,獲取翻頁(yè)的a標(biāo)簽,為其加載翻頁(yè)功能。
- 設(shè)置pageNum,這個(gè)肯定必須傳遞
- 獲取局部刷新div,這個(gè)地方以后有待改善,通過(guò)id獲取好像不太好。
- 傳遞額外參數(shù)urlParas
- 最后阻止a標(biāo)簽既有事件。
/** * 翻頁(yè) * * @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"); // 設(shè)置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請(qǐng)求的url
- 獲取ajax請(qǐng)求的參數(shù)data
- 至于ajaxUrl方法,請(qǐng)參照我的再談ajax局部刷新,我覺(jué)得這樣局部刷新還是很實(shí)用的。
到這,前臺(tái)的內(nèi)容都OK了,接下來(lái)需要什么呢?自然是jfinal端的數(shù)據(jù)獲取。
④、分頁(yè)數(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)提供了很好的翻頁(yè)功能paginate方法。
- 就只需要把對(duì)應(yīng)的數(shù)據(jù)返回就可以了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于A(yíng)ptana Studio生成自動(dòng)備份文件的解決辦法
關(guān)于A(yíng)ptana Studio生成自動(dòng)備份文件的解決辦法2009-12-12JavaScript requestAnimationFrame動(dòng)畫(huà)詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript requestAnimationFrame動(dòng)畫(huà),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09Firefox和IE瀏覽器兼容JS腳本寫(xiě)法小結(jié)
window.event兼容腳本 1.2.屏蔽Form提交事件 3.獲取事件源 4.添加事件兼容寫(xiě)法 5.Firefox注冊(cè)innerText寫(xiě)法 6.長(zhǎng)度 7.父控件下的子控件 8.XmlHttp2008-07-07JavaScript函數(shù)式編程實(shí)現(xiàn)介紹
函數(shù)式編程是一種編程范式,將整個(gè)程序都由函數(shù)調(diào)用以及函數(shù)組合構(gòu)成。 可以看成一條流水線(xiàn),數(shù)據(jù)可以不斷地從一個(gè)函數(shù)的輸出流入另一個(gè)函數(shù)的輸入,最后輸出結(jié)果2022-09-09javascript拖曳互換div的位置實(shí)現(xiàn)示例
一個(gè)div拖動(dòng)互換位置的demo,還有很大優(yōu)化的空間,利用dom元素的dragstart/ondragover/ondrop事件完成,感興趣的可以了解一下2021-06-06深入理解JavaScript 中的執(zhí)行上下文和執(zhí)行棧
這篇文章主要介紹了JavaScript 中的執(zhí)行上下文和執(zhí)行棧的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10JS解析url查詢(xún)參數(shù)的簡(jiǎn)單代碼
本文通過(guò)簡(jiǎn)單代碼給大家介紹了js解析url查詢(xún)參數(shù)的方法,然后在文章下面給大家介紹了js獲取url參數(shù)值的兩種方式 ,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-08-08