基于jquery的分页插件

jquery + ajax + bootstrp的插件

1、js 代码

  

/*author:gj
*调用方式:$(分页父元素id).paging(请求地址,请求数据,列表展示函数给插件调用)
*$("#pagebox").paging("www.aijia.com",{},pageList);
*/
$.extend($.fn, {
paging: function (action, postData, pageList, pageindex) {//(请求地址,请求参数,列表展示函数)
var that = $(this);
var output = {};
var pageCount = 10; //总页数
var pageIndex = 1;//当前页
var pageTotal = 100;//总条数
var pageperCount = 10;//每页多少条
pageperCount = postData.pageSize;
//绑定插件初始加载第一页
pageIndex = pageindex;
paginbyIndex(pageIndex);
//分页获取数据的方法
function getData(index) {
postData = $.extend(postData, { pageIndex: pageIndex })
$.ajax({
type: "post", //使用get方法访问后台
dataType: "json", //返回json格式的数据
url: action, //要访问的后台地址
async: false,
data: postData, //要发送的数据
ajaxStart: function () { /*$("#load").show(); */
},
complete: function () { /*$("#load").hide();*/
}, //AJAX请求完成时隐藏loading提示
success: function (msg) {//msg为返回的数据,在这里做数据绑定
jsonData = eval(msg);
//if (pageIndex == 1) {
if (typeof (jsonData) != "undefined")
{
if (!msg.IsOk)
{
alert(msg.Msg);
return;
}
var data = eval(msg.Data);
pageTotal = jsonData.Total;
pageCount = Math.ceil(pageTotal / pageperCount);
var statistics = {};
if (msg.Msg == "" || typeof (msg.Msg) == "undefined") {
statistics = {};
} else if (isJson(msg.Msg)) {
statistics = msg.Msg;
} else {
statistics = JSON.parse(msg.Msg);
}
pageList(data, pageTotal, pageCount, pageIndex, statistics);
creatPaginBar();
}

}
});

}
//判断是否是json数据
function isJson(obj) {
var isjson = typeof (obj) == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length;
return isjson;
}
//下一页事件
function nextPage() {
if (pageIndex >= pageCount) {
pageIndex = pageCount;
} else {
pageIndex++;
}
getData(pageIndex);

}
//上一页
function upPage() {
if (pageIndex == 1) {
pageIndex = 1;
} else {
pageIndex--;
}
getData(pageIndex);

}
//当前页
function paginbyIndex(index) {
pageIndex = parseInt(index) > 0 ? index : 1;
getData(pageIndex);

}
function creatPaginBar() {
$(that).html("");
if (pageCount <= 0) {
$(that).html("没有找到相应的数据");
return;
}
var html = "";
//如果当前页是第一页,则上一页不能操作
if (pageIndex == 1) {
html += '<li class="prev disabled"><a href="#">← Prev</a></li>';
} else {
html += '<li class="prev page-up-action"><a href="#">← Prev</a></li>';
}
if (pageCount <= 8) {
//如果总页数小于等于8条,全部显示
for (var i = 1; i <= pageCount; i++) {
if (pageIndex == i) {
html += '<li class="active" data=' + i + '><a href="#">' + i + '</a></li>';
} else {
html += ' <li class="page-num" data=' + i + '><a href="#">' + i + '</a></li>';
}

}
} else {
if (pageIndex < 6) {
//如果当前页少于6,前面显示6个
for (var i = 1; i <= 6; i++) {
if (pageIndex == i) {
html += '<li class="active" data=' + i + '><a href="#">' + i + '</a></li>';
} else {
html += ' <li class="page-num" data=' + i + '><a href="#">' + i + '</a></li>';
}
}
//第七个显示。。。
html += '<li class="active"><a href="#">...</a></li>';
//最后一个
html += ' <li class="page-num" data=' + pageCount + '><a href="#">' + pageCount + '</a></li>';
} else if (pageIndex > (pageCount - 4)) {
//如果当前页在最后的5个里,最后5个都显示
html += ' <li class="page-num" data="1" ><a href="#">' + 1 + '</a></li>';
html += ' <li class="page-num" data="2" ><a href="#">' + 2 + '</a></li>';
html += '<li class="active"><a href="#">...</a></li>';
for (var i = pageCount - 4; i <= pageCount; i++) {
if (i == pageIndex) {
html += '<li class="active" data=' + i + '><a href="#">' + i + '</a></li>';
} else {
html += ' <li class="page-num" data=' + i + '><a href="#">' + i + '</a></li>';
}
}
} else {
html += ' <li class="page-num" data="1"><a href="#">' + 1 + '</a></li>';
html += ' <li class="page-num" data="2"><a href="#">' + 2 + '</a></li>';
html += ' <li class="active"><a href="#">...</a></li>';
var q = pageIndex - 1;
var h = pageIndex + 1;
html += ' <li class="page-num" data=' + q + '><a href="#">' + q + '</a></li>';
html += '<li class="active" data=' + pageIndex + '><a href="#">' + pageIndex + '</a></li>';
html += ' <li class="page-num" data=' + h + '><a href="#">' + h + '</a></li>';
//第七个显示。。。
html += '<li class="active"><a href="#">...</a></li>';
//最后一个
html += ' <li class="page-num" data=' + pageCount + '><a href="#">' + pageCount + '</a></li>';
}
}
//下一页
if (pageIndex == pageCount) {//最后一页,不能操作
html += '<li class="next disabled" ><a href="#">Next →</a></li>';
} else {
html += '<li class="next page-next-action" ><a href="#">Next →</a></li>';
}
//html += '<span class="page-count">共' + pageCount + '页</span>';
$(that).html(html);
//上一页
$(that).find(".page-up-action").on("click", function () {
upPage();
});
//下一页
$(that).find(".page-next-action").on("click", function () {
nextPage();
});
//中间
$(that).find(".page-num").on("click", function () {
paginbyIndex(parseInt($(this).attr("data")));
});
}
return output;
}
});
2.页面调用

<!--分页控件-->
<div class="row">
<div class="col-md-6">

</div>
<div class="col-md-6">
<div class="dataTables_paginate paging_bootstrap pagination" style="float:right;">

      <!--分页控件标签-->
      <ul class="pagination" id="pagin"></ul>
</div>
</div>
</div>

页面脚本调用

 

<script type="text/javascript">

   分页控件的执行函数

"/Filled/GetPayAmountList":请求的服务端地址

postData:提交的json数据

CreatTableBody:生成数据结果的展现

function AjaxSearch(postData) {
$('#pagin').paging("/Filled/GetPayAmountList", postData, CreatTableBody, postData.pageIndex);
}

//绑定数据

jsondata:查询回来的数据

pageTotal:总条数

pageCount:总页数

pageIndex:每页显示多少条
function CreatTableBody(jsondata, pageTotal, pageCount, pageIndex) {
var html = "";
if (jsondata != null && jsondata.length > 0) {
$.each(jsondata, function (i, item) {
html += stringFormat("<tr>");
html += stringFormat("<td><input name='cid' type='checkbox' value='{0}'/></td>", item.ID);
html += stringFormat("<td>{0}</td>", item.Limit);
html += stringFormat("<td>{0}</td>", item.PresentCurrency);
html += stringFormat("<td><a href=\"javascript:void(0)\" onclick=\"update({0},{1},{2})\">编辑</a>&nbsp;&nbsp;<a href=\"javascript:void(0)\" onclick=\"del({0})\">删除</a></td>", item.ID, item.Limit, item.PresentCurrency);
html += "</tr>";
});
}
$("#DataTables_Table_0_wrapper tbody").html(html);
$("#DataTables_Table_0_info").html(stringFormat("显示 {0} 至 {1} 共 {2} 条", ((pageIndex - 1) * postData.pageSize + 1), ((pageIndex * postData.pageSize) < pageTotal ? (pageIndex * postData.pageSize) : pageTotal), pageTotal));
}

</script>

posted on 2018-05-10 16:56  有境乃达  阅读(245)  评论(0编辑  收藏  举报

导航