• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Bootstrap实现翻页效果

php 搞代码 3年前 (2022-01-22) 36次浏览 已收录 0个评论

Bootstrap,来自 Twitter,是目前很受欢迎的前端框架。Bootstrap 是基于 HTML、CSS、JavaScript 的,它简洁灵活,使得 Web 开发更加快捷。本文主要为大家详细介绍了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:要刷新哪一个p的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:局部刷新p的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,这个肯定必须传递

  • 获取局部刷新p,这个地方以后有待改善,通过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"); // 设置p上的其他参数 if (dataId) {  if (dataId.indexOf(",") != -1) {  $.each(da<div style="color:transparent">本文来源gaodai.ma#com搞##代!^码@网*</div><pre>搞gaodaima代码

taId.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 Table 服务端处理分页

求PHP+SQLServer的翻页效果,该怎么处理

简单做出HTML5翻页效果文字特效

以上就是Bootstrap实现翻页效果的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Bootstrap实现翻页效果

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址