前言:《实现bootstrap到jfinal的翻页功能》,本篇绝对纯干货,优点:支持局部刷新;只要是列表,都可以加载该组件;支持动态数据绑定;当然还有绝对的简单实用。
1.我最喜欢的就是局部刷新,哈哈。
2.参数传递起来也很简单。
第一步,构造翻页组件。
<%@ 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>
1. pageNum:第几页
2. rel:要刷新哪一个div的id
3. 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="" />
<ul class="thumbnails">
<c:forEach items="${dealPage.list}" var="deal">
<li class="span4">
<div class="thumbnail">
<a title="${deal.name}" href="${ctx}/deal/showDealDetail/${deal.id}">
<img src="${deal.image}" style="width: 300px; height: 150px;" alt=""></img>
</a>
</div>
</li>
</c:forEach>
</ul>
<%@ include file="/components/common/paginate.jsp"%>
1. currentPage:页数
2. totalPage:总页数
3. rel:局部刷新div的id
4. urlParas:其他参数,暂无
第三步,局部刷新的div
<div class="col-md-6" url="${ctx}/mem/showDeal" id="deal_items" data="deal_type"></div>
此处,你可以参照我的再谈ajax局部刷新,我觉得这样局部刷新还是很实用的。
第四步,启用翻页功能
$(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;
});
});
});
1. 页面加载完成后,获取翻页的a标签,为其加载翻页功能。
2. 设置pageNum,这个肯定必须传递
3. 获取局部刷新div,这个地方以后有待改善,通过id获取好像不太好。
4. 传递额外参数urlParas
5. 最后阻止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);
}
});
}
}
1. 这串代码也很好懂,获取ajax请求的url
2. 获取ajax请求的参数data
3. 至于ajaxUrl方法,请参照我的再谈ajax局部刷新,我觉得这样局部刷新还是很实用的。
到这,前台的内容都OK了,接下来需要什么呢?自然是jfinal端的数据获取。
第五步,通过jfinal获取数据
public void showDeal() {
logger.info("展示我的项目信息");
try {
// 我创建的项目
Page<Deals> myDeals = Deals.me.paginateCreateDealsByUid(getParaToInt("pageNum", 1), 10, me.getLong("uid"));
setAttr("dealPage", myDeals);
render("deal.jsp");
} catch (Exception e) {
logger.error(e.getMessage(), e);
redirect("/error404");
}
}
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;
}
1. jfinal自然已经提供了很好的翻页功能paginate方法。
2. 就只需要把对应的数据返回就可以了。
结语:车到山前必有路,昨天没有弄出来,经过一晚上的思考,今天思路就比较清晰,所以希望对大家有所帮助。
版权声明:本站博客均为qing_gee原创文章,请勿引用或者转载。
原文:http://blog.csdn.net/qing_gee/article/details/49150353