php 无刷新表格,基于jQuery实现的无刷新表格分页实例_jquery

本文介绍了一种使用jQuery实现的无刷新表格分页方法。首先展示了分页效果,接着给出了HTML结构、CSS样式和JavaScript封装代码。在JavaScript部分,定义了抽象化表格类和表格对象模板,并实现了分页功能,包括获取列数、表格内容展示、分页行为等。此外,还详细展示了如何在表格底部创建分页链接并进行事件绑定,确保分页功能的正常工作。
摘要由CSDN通过智能技术生成

本文实例讲述了基于jQuery实现的无刷新表格分页。分享给大家供大家参考,具体如下:

效果图如下:

5329cb5baa50e2523ee99e7501da1608.png

html结构:

css样式:

html,body{margin: 0;padding:0}

a:focus {outline: none;}

/* 通用表格显示 */

table, th, td {font: 12px Arial,Helvetica,sans-serif,'宋体';margin: 0;padding: 0}

table{border-spacing: 0;border-collapse: collapse;}

.datatable {width: 100%;border-style: none;background-color: #fff;margin-bottom: 20px;text-align: left;}

.datatable th, .datatable td { padding: 5px;line-height: 30px}

.datatable thead th {background-color: #eee;margin: 0;text-align: left;border-top: 1px solid #cfcfcf;border-bottom: 1px solid #cfcfcf;font-weight: 500}

.datatable tbody td {background-color: #fff;border-bottom: 1px solid #ddd;table-layout:fixed;word-break:break-all;font-weight: 400}

.datatable tbody tr.evenrow td {background-color: #f4f4f4;}

.datatable tfoot td {background-color: #fafafa;text-align: right;border-bottom: 1px solid #cfcfcf;}

/*表格分页列表*/

.datatable td.paging a {border: 1px solid #eee; color: #444; margin: 4px; padding: 2px 7px; text-decoration: none; text-align:center;}

/*表格分页当前页*/

.datatable td.paging a.current {background: #eee; border: 1px solid #CFCFCF; color: #444; font-weight: bold;}

.datatable td.paging a.current{border: 0;cursor: auto;background:none}

javascript封装代码:

/**

* 抽象化表格

*/

function abstractTable(){

// ---------内容属性

this.id = null; // 每个表格都有唯一的一个id

this.tableobj = null; //表格对象

this.rowNum = 0; //行数

this.colNum = 0; //列数

this.header = []; //表头数据

this.content = []; //body数据

// ----------提供外部使用获得表格内部数据

this.currentClickRowID = 0; //当前点击的行数据

// --- 通过表头来获得这张表的列数

this.getColNum = function(){

this.colNum = this.header.length;

return this.colNum;

}

// ----------- 表格自我构建行为

this.clearTable = function(){};

this.showHeader = function(){};

this.showContent = function(begin,end){};

this.showFoot = function(){};

// --------- 分页功能属性

this.allDataNum = 0; // 总数据条数

this.displayNum = 10; // 每页显示条数

this.maxPageNum = 0; // 最大页码值

this.currentPageNum =1;// 当前页码值

//tfoot分页组

this.groupDataNum = 10; //每组显示10页

this.groupNum = 1; //当前组

// -------- 分页功能行为

this.paginationFromBeginToEnd = function(begin,end){}

this.first = function(){}//首页

this.last = function(){}//最后一页

this.prev = function(){}//上一页

this.next = function(){}//下一页

this.goto = function(){} //跳到某页

// ----------- 表格初始化

this.init = function(begin,end){}

}

/*

表格对象模板

*/

function tableTemplet(table_id){

abstractTable.call(this);

this.id = table_id;

}

/**

* 表格对象

* @param options

*/

function table(options){

if(!options){return;}

if(!$.isPlainObject(options)){return;}

tableTemplet.call(this,options.tableId);

//得到表格对象

this.tableobj = $("#"+this.id);

//清空表格内容

this.clearTable = function(){

this.tableobj.html(" ");

}

// 实现分页行为

this.paginationFromBeginToEnd= function(x,y){

this.maxPageNum = Math.ceil(this.allDataNum/this.displayNum);

var arrPage = [];

for(var i= x;i"),

$tr = $("

"),

$th;

for(var i=0;i").html(this.header[i]);

$th.appendTo($tr);

}

$tr.appendTo($thead);

$thead.appendTo(this.tableobj)

}

}

//初始化tbody

this.showContent = function(begin,end){

if(this.content != null){

var $tbody = $(""),

$tr,

$td;

var tempDaTa = this.paginationFromBeginToEnd(begin,end),

len = tempDaTa.length;

// 循环创建行

for(var i=0;i").appendTo($tbody);

if(i%2==1){

$tr.addClass("evenrow");

}

// 循环创建列 取得对象中的键

for(var key in tempDaTa[i]){

$td = $("").html(tempDaTa[i][key]).appendTo($tr);

}

}

this.tableobj.append($tbody);

}

}

//初始化tfoot

this.showFoot = function(){

var $tfoot = $(""),

$tr = $("

"),

$td = $("").attr("colspan",this.colNum).addClass("paging");

$tr.append($td);

$tfoot.append($tr);

this.tableobj.append($tfoot);

this.pagination($td);

}

//表格分页

this.pagination = function(tdCell){

var $td= typeof(tdCell) == "object" ? tdCell : $("#" + tdCell);

//首页

var oA = $("");

oA.attr("href","#1");

oA.html("首页");

$td.append(oA);

//上一页

if(this.currentPageNum>=2){

var oA = $("");

oA.attr("href","#"+(this.currentPageNum - 1));

oA.html("上一页");

$td.append(oA);

}

//普通显示格式

if(this.maxPageNum <= this.groupDataNum){ // 10页以内 为一组

for(var i = 1;i <= this.maxPageNum ;i++){

var oA = $("");

oA.attr("href","#"+i);

if(this.currentPageNum == i){

oA.attr("class","current");

}

oA.html(i);

$td.append(oA);

}

}else{//超过10页以后(也就是第一组后)

if(this.groupNum<=1){//第一组显示

for(var j = 1;j <= this.groupDataNum ;j++){

var oA = $("");

oA.attr("href","#"+j);

if(this.currentPageNum == j){

oA.attr("class","current");

}

oA.html(j);

$td.append(oA);

}

}else{//第二组后面的显示

var begin = (this.groupDataNum*(this.groupNum-1))+ 1,

end ,

maxGroupNum = Math.ceil(this.maxPageNum/this.groupDataNum);

if(this.maxPageNum%this.groupDataNum!=0&&this.groupNum==maxGroupNum){

end = this.groupDataNum*(this.groupNum-1)+this.maxPageNum%this.groupDataNum

}else{

end = this.groupDataNum*(this.groupNum);

}

for(var j = begin;j <= end ;j++){

var oA = $("");

oA.attr("href","#"+j);

if(this.currentPageNum == j){

oA.attr("class","current");

}

oA.html(j);

$td.append(oA);

}

}

}

//下一页

if( (this.maxPageNum - this.currentPageNum) >= 1 ){

var oA = $("");

oA.attr("href","#" + (this.currentPageNum + 1));

oA.html("下一页");

$td.append(oA);

}

//尾页

var oA = $("");

oA.attr("href","#" + this.maxPageNum);

oA.html("尾页");

$td.append(oA);

var page_a = $td.find('a');

var tempThis = this;

page_a.unbind("click").bind("click",function(){

var nowNum = parseInt($(this).attr('href').substring(1));

if(nowNum>tempThis.currentPageNum){//下一组

if(tempThis.currentPageNum%tempThis.groupDataNum==0){

tempThis.groupNum += 1;

var maxGroupNum = Math.ceil(tempThis.maxPageNum/tempThis.groupDataNum);

if(tempThis.groupNum>=maxGroupNum){

tempThis.groupNum = maxGroupNum;

}

}

}

if(nowNum

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值