Bootstrap实现翻页效果
时间:2019-04-10
本文章向大家介绍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">←</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方法。
- 就只需要把对应的数据返回就可以了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- HDU 2564 词组缩写
- 约瑟夫问题方法总结
- 欧里几德及扩展欧里几德算法
- Hadoop数据分析平台实战——260用户数据ETL离线数据分析平台实战——260用户数据ETL
- # Hadoop离线数据分析平台实战——230项目数据存储结构设计Hadoop离线数据分析平台实战——230项目数据存储结构设计
- ECJTUACM16 Winter vacation training #5 题解&源码
- Codeforces 716A Crazy Computer
- Hadoop数据分析平台实战——240JavaSDK数据收集引擎编写离线数据分析平台实战——240JavaSDK数据收集引擎编写
- Hadoop离线数据分析平台实战——290活跃用户分析Hadoop离线数据分析平台实战——290活跃用户分析
- Codeforces 719B Anatoly and Cockroaches
- 【一起学Python】爬取前程无忧招聘信息并写入Excel
- 【一起学Python】爬取网易云歌词
- Hadoop离线数据分析平台实战——370外链信息分析Hadoop离线数据分析平台实战——370外链信息分析
- POJ 1067 取石子游戏
- HTML 教程
- HTML 简介
- html div 标签介绍
- html span 标签介绍
- html a 超链接标签
- HTML Br换行标签介绍
- HTML P段落标签介绍
- HTML br与p标签区别
- Html H 标题标签
- html px em pt长度单位
- HTML form 标签
- HTML radio 单选框
- HTML B 加粗标签
- HTML strong加粗粗体标签
- HTML em 强调标签
- HTML i 斜体标签
- HTML u下划线标签
- HTML s 删除线标签
- Html img 图片标签
- Html上标注sup与下标注sub标签
- HTML nobr 禁止换行标签
- HTML hr 水平线标签
- HTML label 标签
- HTML input 标签
- HTML textarea 标签
- HTML select下拉列表标签
- HTML checkbox 多选框
- HTML font color 标签
- HTML iframe 框架标签
- HTML Table 表格
- HTML dl dt dd 标签
- HTML ol li有序列表标签
- HTML ul li 无序列表标签
- HTML 注释
- CSS 教程
- CSS 简介
- CSS 语法
- CSS Id 和 Class选择器
- CSS 样式的创建
- CSS background 背景介绍
- CSS 文本样式
- CSS font 字体
- CSS A 链接
- CSS ul ol列表样式
- CSS TABLE 样式
- CSS 框模型
- CSS border 边框
- CSS Outlines 轮廓
- CSS 外边距 Margin
- CSS Padding 内边距
- CSS 分组和嵌套选择器
- CSS 尺寸 (Dimension)
- CSS Display 属性
- CSS Position 定位
- CSS Float 浮动
- CSS 水平对齐(Horizontal Align)
- CSS 组合选择符
- CSS 伪类
- CSS 伪元素
- CSS 导航栏
- CSS 下拉菜单
- CSS 图片廊
- CSS 图像透明/不透明
- CSS sprite 图像拼合技术
- CSS 媒体类型
- CSS 属性选择器
- CSS 实例
- 谈谈Gaussian软件中的guess=mix
- 用ORCA做DLPNO-CCSD(T)计算
- Fortran调用C函数
- 在Python中创建命令行界面的最佳方式
- Diels-Alder反应的区域选择性分析
- 传说中的画图神器Plotnine,Python中的ggplot2
- 用ORCA做结构优化及轨迹查看
- 前端兼容之痛
- 离线安装PySCF程序(1.5及更高版本)
- Python Debug(调试)的终极指南
- Linux下做计算常用的别名alias推荐
- 离线安装支持Intel MKL的R-3.6
- Dalton使用——磷光及其相关过程
- 【赵渝强老师】Flink的Watermark机制(基于Flink 1.11.0实现)
- 在Windows CMD里“使用”常见Linux命令