Javascript表格翻頁效果的具體實現(xiàn)
更新時間:2013年10月05日 17:35:26 作者:
表格翻頁的實現(xiàn)方式有很多,下面以js為例為大家詳細(xì)介紹下表格翻頁效果的具體實現(xiàn),感興趣的朋友可不要錯過
表格翻頁的實現(xiàn)方式有很多,下面以js為例為大家詳細(xì)介紹下表格翻頁效果的具體實現(xiàn)。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>表格翻頁---www.dbjr.com.cn</TITLE>
<style>
body, td{
font-size: 9pt;
}
a:link {
color: #FF0000;
}
a:visited {
color: #FF0000;
}
a:hover {
color: #006600;
}
</style>
<SCRIPT LANGUAGE="JavaScript">
<!--
var record = 4;//每頁顯示多少條記錄
var count = 24;//記錄總數(shù)
var pageTotal = ((count+record-1)/record)|0;//總頁數(shù)
var pagenum = 1;//將要顯示的頁碼
Cookie = {
Set : function (){
var name = arguments[0], value = escape(arguments[1]), days = 365, path = "/";
if(arguments.length > 2) days = arguments[2];
if(arguments.length > 3) path = arguments[3];
with(new Date()){
setDate(getDate()+days);
days=toUTCString();
}
document.cookie = "{0}={1};expires={2};path={3}".format(name, value, days, path);
},
Get : function (){
var returnValue=document.cookie.match(new RegExp("[\b\^;]?" + arguments[0] + "=([^;]*)(?=;|\b|$)","i"));
return returnValue?unescape(returnValue[1]):returnValue;
}
}
String.prototype.format = function(){
var tmpStr = this;
var iLen = arguments.length;
for(var i=0;i<iLen;i++){
tmpStr = tmpStr.replace(new RegExp("\\{" + i + "\\}", "g"), arguments[i]);
}
return tmpStr;
}
function setPagenum(){//整理Cookie
pagenum = Cookie.Get("pagenum");
if(pagenum=="" || pagenum<1){
pagenum=1;
}
}
setPagenum();
//重新整理當(dāng)前頁碼,如果頁面小于1,則賦值為1,如果大于總頁數(shù),則等于總頁數(shù)
coordinatePagenum(pagenum);
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里第一條記錄的號碼
var pageBegin = (record*(pagenum-1)+1)|0;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里最后一條記錄的號碼
var pageEnd = record*pagenum;
function showhiddenRecord(pagenum){
number.innerHTML=pagenum;
if(pagenum<=1){
theFirstPage.innerHTML="第一頁";
thePrePage.innerHTML="上一頁";
}else{
theFirstPage.innerHTML="<a href=\"javascript:firstPage()\">第一頁</a>";
thePrePage.innerHTML="<a href=\"javascript:prePage()\">上一頁</a>";
}
if(pagenum>=pageTotal){
theNextPage.innerHTML="下一頁";
theLastPage.innerHTML="最后一頁";
}else{
theNextPage.innerHTML="<a href=\"javascript:nextPage()\">下一頁</a>";
theLastPage.innerHTML="<a href=\"javascript:lastPage()\">最后一頁</a>";
}
document.getElementById('goto').value=pagenum;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里第一條記錄的號碼
pageBegin = (record*(pagenum-1)+1)|0;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里最后一條記錄的號碼
pageEnd = record*pagenum;
for(var i=1;i<=count;i++){
if(i>=pageBegin && i<=pageEnd){
mytable.rows[i].style.display="";
}else{
mytable.rows[i].style.display="none";
}
}
Cookie.Set("pagenum", pagenum);
}
function firstPage(){
pagenum=1;
showhiddenRecord(pagenum);
}
function lastPage(){
showhiddenRecord(pageTotal);
}
//重新整理當(dāng)前頁碼,如果頁面小于1,則賦值為1,如果大于總頁數(shù),則等于總頁數(shù)
function coordinatePagenum(num){
if(num<1){
num="1";
}else if(num>pageTotal){
num=pageTotal;
}
}
function prePage(){
pagenum--;
coordinatePagenum(pagenum);
showhiddenRecord(pagenum);
}
function nextPage(){
pagenum++;
coordinatePagenum(pagenum);
showhiddenRecord(pagenum);
}
function gotoPage(num){
coordinatePagenum(pagenum);
showhiddenRecord(num);
}
//-->
</SCRIPT>
</HEAD>
<BODY onLoad="showhiddenRecord(pagenum)">
<center>
共 6 頁 當(dāng)前第 <span id="number">1</span> 頁
<span id="theFirstPage"><a href="javascript:firstPage()">第一頁</a></span>
<span id="thePrePage"><a href="javascript:prePage()">上一頁</a></span>
<span id="theNextPage"><a href="javascript:nextPage()">下一頁</a></span>
<span id="theLastPage"><a href="javascript:lastPage()">最后一頁</a></span>
轉(zhuǎn)到第<select onChange="gotoPage(this.value)" name="goto">
<option value=1>1</option>
<option value=2>2</option>
<option value=3>3</option>
<option value=4>4</option>
<option value=5>5</option>
<option value=6>6</option>
</select>頁
</center>
<TABLE id="mytable" cellpadding=4 cellspacing=1 border=0 bgcolor=#999999 width=500 align=center>
<TR bgcolor=#ffffff><TD>標(biāo)題</TD></TR>
<TR bgcolor=#ffffff><TD>1</TD></TR>
<TR bgcolor=#ffffff><TD>2</TD></TR>
<TR bgcolor=#ffffff><TD>3</TD></TR>
<TR bgcolor=#ffffff><TD>4</TD></TR>
<TR bgcolor=#ffffff><TD>5</TD></TR>
<TR bgcolor=#ffffff><TD>6</TD></TR>
<TR bgcolor=#ffffff><TD>7</TD></TR>
<TR bgcolor=#ffffff><TD>8</TD></TR>
<TR bgcolor=#ffffff><TD>9</TD></TR>
<TR bgcolor=#ffffff><TD>10</TD></TR>
<TR bgcolor=#ffffff><TD>11</TD></TR>
<TR bgcolor=#ffffff><TD>12</TD></TR>
<TR bgcolor=#ffffff><TD>13</TD></TR>
<TR bgcolor=#ffffff><TD>14</TD></TR>
<TR bgcolor=#ffffff><TD>15</TD></TR>
<TR bgcolor=#ffffff><TD>16</TD></TR>
<TR bgcolor=#ffffff><TD>17</TD></TR>
<TR bgcolor=#ffffff><TD>18</TD></TR>
<TR bgcolor=#ffffff><TD>19</TD></TR>
<TR bgcolor=#ffffff><TD>20</TD></TR>
<TR bgcolor=#ffffff><TD>21</TD></TR>
<TR bgcolor=#ffffff><TD>22</TD></TR>
<TR bgcolor=#ffffff><TD>23</TD></TR>
<TR bgcolor=#ffffff><TD>24</TD></TR>
</TABLE>
</BODY>
</HTML>
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>表格翻頁---www.dbjr.com.cn</TITLE>
<style>
body, td{
font-size: 9pt;
}
a:link {
color: #FF0000;
}
a:visited {
color: #FF0000;
}
a:hover {
color: #006600;
}
</style>
<SCRIPT LANGUAGE="JavaScript">
<!--
var record = 4;//每頁顯示多少條記錄
var count = 24;//記錄總數(shù)
var pageTotal = ((count+record-1)/record)|0;//總頁數(shù)
var pagenum = 1;//將要顯示的頁碼
Cookie = {
Set : function (){
var name = arguments[0], value = escape(arguments[1]), days = 365, path = "/";
if(arguments.length > 2) days = arguments[2];
if(arguments.length > 3) path = arguments[3];
with(new Date()){
setDate(getDate()+days);
days=toUTCString();
}
document.cookie = "{0}={1};expires={2};path={3}".format(name, value, days, path);
},
Get : function (){
var returnValue=document.cookie.match(new RegExp("[\b\^;]?" + arguments[0] + "=([^;]*)(?=;|\b|$)","i"));
return returnValue?unescape(returnValue[1]):returnValue;
}
}
String.prototype.format = function(){
var tmpStr = this;
var iLen = arguments.length;
for(var i=0;i<iLen;i++){
tmpStr = tmpStr.replace(new RegExp("\\{" + i + "\\}", "g"), arguments[i]);
}
return tmpStr;
}
function setPagenum(){//整理Cookie
pagenum = Cookie.Get("pagenum");
if(pagenum=="" || pagenum<1){
pagenum=1;
}
}
setPagenum();
//重新整理當(dāng)前頁碼,如果頁面小于1,則賦值為1,如果大于總頁數(shù),則等于總頁數(shù)
coordinatePagenum(pagenum);
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里第一條記錄的號碼
var pageBegin = (record*(pagenum-1)+1)|0;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里最后一條記錄的號碼
var pageEnd = record*pagenum;
function showhiddenRecord(pagenum){
number.innerHTML=pagenum;
if(pagenum<=1){
theFirstPage.innerHTML="第一頁";
thePrePage.innerHTML="上一頁";
}else{
theFirstPage.innerHTML="<a href=\"javascript:firstPage()\">第一頁</a>";
thePrePage.innerHTML="<a href=\"javascript:prePage()\">上一頁</a>";
}
if(pagenum>=pageTotal){
theNextPage.innerHTML="下一頁";
theLastPage.innerHTML="最后一頁";
}else{
theNextPage.innerHTML="<a href=\"javascript:nextPage()\">下一頁</a>";
theLastPage.innerHTML="<a href=\"javascript:lastPage()\">最后一頁</a>";
}
document.getElementById('goto').value=pagenum;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里第一條記錄的號碼
pageBegin = (record*(pagenum-1)+1)|0;
//根據(jù)當(dāng)前要顯示的頁碼取得當(dāng)前面里最后一條記錄的號碼
pageEnd = record*pagenum;
for(var i=1;i<=count;i++){
if(i>=pageBegin && i<=pageEnd){
mytable.rows[i].style.display="";
}else{
mytable.rows[i].style.display="none";
}
}
Cookie.Set("pagenum", pagenum);
}
function firstPage(){
pagenum=1;
showhiddenRecord(pagenum);
}
function lastPage(){
showhiddenRecord(pageTotal);
}
//重新整理當(dāng)前頁碼,如果頁面小于1,則賦值為1,如果大于總頁數(shù),則等于總頁數(shù)
function coordinatePagenum(num){
if(num<1){
num="1";
}else if(num>pageTotal){
num=pageTotal;
}
}
function prePage(){
pagenum--;
coordinatePagenum(pagenum);
showhiddenRecord(pagenum);
}
function nextPage(){
pagenum++;
coordinatePagenum(pagenum);
showhiddenRecord(pagenum);
}
function gotoPage(num){
coordinatePagenum(pagenum);
showhiddenRecord(num);
}
//-->
</SCRIPT>
</HEAD>
<BODY onLoad="showhiddenRecord(pagenum)">
<center>
共 6 頁 當(dāng)前第 <span id="number">1</span> 頁
<span id="theFirstPage"><a href="javascript:firstPage()">第一頁</a></span>
<span id="thePrePage"><a href="javascript:prePage()">上一頁</a></span>
<span id="theNextPage"><a href="javascript:nextPage()">下一頁</a></span>
<span id="theLastPage"><a href="javascript:lastPage()">最后一頁</a></span>
轉(zhuǎn)到第<select onChange="gotoPage(this.value)" name="goto">
<option value=1>1</option>
<option value=2>2</option>
<option value=3>3</option>
<option value=4>4</option>
<option value=5>5</option>
<option value=6>6</option>
</select>頁
</center>
<TABLE id="mytable" cellpadding=4 cellspacing=1 border=0 bgcolor=#999999 width=500 align=center>
<TR bgcolor=#ffffff><TD>標(biāo)題</TD></TR>
<TR bgcolor=#ffffff><TD>1</TD></TR>
<TR bgcolor=#ffffff><TD>2</TD></TR>
<TR bgcolor=#ffffff><TD>3</TD></TR>
<TR bgcolor=#ffffff><TD>4</TD></TR>
<TR bgcolor=#ffffff><TD>5</TD></TR>
<TR bgcolor=#ffffff><TD>6</TD></TR>
<TR bgcolor=#ffffff><TD>7</TD></TR>
<TR bgcolor=#ffffff><TD>8</TD></TR>
<TR bgcolor=#ffffff><TD>9</TD></TR>
<TR bgcolor=#ffffff><TD>10</TD></TR>
<TR bgcolor=#ffffff><TD>11</TD></TR>
<TR bgcolor=#ffffff><TD>12</TD></TR>
<TR bgcolor=#ffffff><TD>13</TD></TR>
<TR bgcolor=#ffffff><TD>14</TD></TR>
<TR bgcolor=#ffffff><TD>15</TD></TR>
<TR bgcolor=#ffffff><TD>16</TD></TR>
<TR bgcolor=#ffffff><TD>17</TD></TR>
<TR bgcolor=#ffffff><TD>18</TD></TR>
<TR bgcolor=#ffffff><TD>19</TD></TR>
<TR bgcolor=#ffffff><TD>20</TD></TR>
<TR bgcolor=#ffffff><TD>21</TD></TR>
<TR bgcolor=#ffffff><TD>22</TD></TR>
<TR bgcolor=#ffffff><TD>23</TD></TR>
<TR bgcolor=#ffffff><TD>24</TD></TR>
</TABLE>
</BODY>
</HTML>
相關(guān)文章
JavaScript高級程序設(shè)計閱讀筆記(十六) javascript檢測瀏覽器和操作系統(tǒng)-detect.js
javascript檢測瀏覽器和操作系統(tǒng) detect.js使用介紹,需要的朋友可以參考下2012-08-08javascript的漸進(jìn)增強與平穩(wěn)退化淺談
2013-11-11javascript實現(xiàn)動態(tài)側(cè)邊欄代碼
這篇文章主要介紹了javascript實現(xiàn)動態(tài)側(cè)邊欄代碼,需要的朋友可以參考下2014-02-02javascript中利用柯里化函數(shù)實現(xiàn)bind方法
這篇文章主要為大家詳細(xì)介紹了javascript中利用柯里化函數(shù)實現(xiàn)bind方法,感興趣的小伙伴們可以參考一下2016-04-04基于javascript實現(xiàn)按圓形排列DIV元素(二)
本篇文章主要介紹基于javascript實現(xiàn)按圓形排列DIV元素的方法,此文著重于介紹怎樣實現(xiàn)的按圓形排列DIV元素的運動原理和實現(xiàn)效果代碼,需要的朋友來看下吧2016-12-12JavaScript中關(guān)于Object.create()的用法
這篇文章主要介紹了JavaScript中關(guān)于Object.create()的用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02ajax如何實現(xiàn)頁面局部跳轉(zhuǎn)與結(jié)果返回
AJAX即“Asynchronous Javascript And XML”(異步JavaScript和XML),是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù),通過在后臺與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁實現(xiàn)異步更新,本篇文章給大家介紹ajax如何實現(xiàn)頁面局部跳轉(zhuǎn)與結(jié)果返回,感興趣的朋友一起來學(xué)習(xí)2015-08-08