JavaScript

超轻量级php框架startmvc

Bootstrap实现翻页效果

更新时间:2020-06-16 21:54:01 作者:startmvc
Bootstrap之翻页。优点:支持局部刷新;只要是列表,都可以加载该组件;支持动态数据绑定

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方法。
  • 就只需要把对应的数据返回就可以了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

Bootstrap 翻页