Bootstrap实现翻页效果

Bootstrap之翻页。

优点:

支持局部刷新;
只要是列表,都可以加载该组件;
支持动态数据绑定;
当然还有绝对的简单实用。

效果图

最后一页时:

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\">&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:其他参数

②、调用翻页组件

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

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

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容