Home > Web Front-end > JS Tutorial > body text

Pure js paging code (concise and practical)_javascript skills

WBOY
Release: 2016-05-16 17:17:30
Original
1223 people have browsed it

Copy code The code is as follows:

//每页显示字数
PageSize=5000;
//分页模式
flag=2;//1:根据字数自动分页 2:根据[NextPage]分页
//默认页
startpage = 1;
//导航显示样式 0:常规 1:直接 3:下拉
TopShowStyle = 1;
DownShowStyle = 0;

 var currentSet,CutFlag,TotalByte,PageCount,key,tempText,tempPage;
 key="";
 currentSet=0;
 var Text=xmlArticle.selectSingleNode("//Content").text;
 TotalByte=Text.length;

 if (flag==1)
 {
  PageCount=Math.round(TotalByte/PageSize);
  if(parseFloat("0."+TotalByte%PageSize)>0){
   if(parseFloat("0."+TotalByte%PageSize)<0.5){
PageCount=PageCount+1;
}
}
var PageNum=new Array(PageCount+1);
var PageTitle=new Array(PageCount+1);
PageNum[0]=0;
PageTitle[0]="";

var sDrv1,sDrv2,sDrv3,sDrv4,sFlag;
var sDrvL,sTemL;
var sTem1,sTem2,k;
sFlag=0;

for(j=1;j PageNum[j]=PageNum[j-1]+PageSize;
PageTitle[j]="";
//alert(j);
sDrv1="
";
   sDrv2="
";
   sDrv3="
";
   sDrv4="
";
   sDrvL=sDrv1.length;
   for(k=PageNum[j];k<=TotalByte;k++){
sTem1=Text.substring(PageNum[j]-sDrvL,k);
sTemL=sTem1.length;
sTem2=sTem1.substring(sTemL-sDrvL,sTemL)
if (sTem2==sDrv1 || sTem2==sDrv2 || sTem2==sDrv3 || sTem2==sDrv4)
{
sFlag=sFlag+1;
PageNum[j]=k;
break;
}
}
if (PageNum[j]>TotalByte)
   {
    break;
   }
  }
  if (j {
PageNum.length=j;
PageCount=j
}
if (PageCount>1&&sFlag>1&&PageCount {
PageCount=sFlag+1;
}
}
else{
//手动分页
var j,sFlag,PageCount,sText;
var sTitleFlag;
var PageNum=new Array();
var PageTitle=new Array();

PageSize=0;
j=1;
PageNum[0]=-10;
PageTitle[0]="";
sFlag=0;
sText=Text;

do
{
sText=Text.substring(PageNum[j-1]+10,TotalByte);

sFlag=sText.indexOf("[NextPage");

if (sText.substring(sFlag+9,sFlag+10)=="=")
{
sTitleFlag=sText.indexOf("]",sFlag);
PageTitle[j]=sText.substring(sFlag+10,sTitleFlag);
}
else{
PageTitle[j]="";
}

if (sFlag>0)
   {
    PageNum[j]=sFlag+PageNum[j-1]+10;
   }
   else{
    PageNum[j]=TotalByte;
   }

   j+=1;
  }
  while (PageNum[j-1]

PageCount=j-1;
}

function text_pagination(Page){
var Output,Byte;

if(Page==null){Page=1;}

Output="";
Output=Output+"

";
  Output=Output+"";
  Output=Output+"";
  Output=Output+"";

  //头部功能导航条
  Output=Output+"

";

   //正文查找

   Output=Output+"

";

   Output=Output+"";
   //}

   //显示方式三
   //页码选择列表
   //Output=Output+"

";

  Output=Output+"

";
  Output=Output+"";
  Output=Output+"";
  Output=Output+"";
  Output=Output+"
 ";
   Output=Output+" ";
   Output=Output+"
";

   //页码显示方式一
   //第x页:分页标题
   if (Page==0 || PageCount==0){
    Output=Output+"当前是:全文显示" ;   
   }
   else{
    if(TotalByte>PageSize){Byte=PageNum[Page]-PageNum[Page-1]}else{Byte=TotalByte};
    Output=Output+"第 "+Page+" 页";
    if (PageTitle[Page]!="")
    {
     Output=Output+":"+PageTitle[Page]+"";
    }
    Output+=' ';
   }

   //显示方式二
   //下拉菜单选择
   //if (PageCount>0)
   //{
   // Output=Output+Article_PageNav(2,Page);
   // Output=Output+" 

";
   //Output=Output+Article_PageNav(0,Page);
   //Output=Output+"
";

  //显示正文
  if(Page==0) {
  //不分页
   tempText=Text;
  }
  else{
  //分页
   if (flag==1)
   //自动分页
   {
    tempText=Text.substring(PageNum[Page-1],PageNum[Page]);
   }
   else{
   //手动分页
    if (PageTitle[Page-1].length==0)
    {
     tempText=Text.substring(PageNum[Page-1]+10,PageNum[Page]);
    }
    else{
     tempText=Text.substring(PageNum[Page-1]+11+PageTitle[Page-1].length,PageNum[Page]);
    }
   }
  }

  //布置内容
  Output=Output+"

";
  Output=Output+Article_PageNav(TopShowStyle,Page);
  Output=Output+"
";

  Output=Output+"
";
  Output=Output+tempText;
  Output=Output+"
";
  Output=Output+"
";

  Output=Output+"

";
  Output=Output+Article_PageNav(DownShowStyle,Page);
  Output=Output+"
";

  article.innerHTML = Output;
  if (Page>1)
  {
   document.location.href='#top';
  }

  eval(document.all.keys).value=key;
  if (key!=""){searchkey();}
 }

 function searchkey(){
  //正文查找函数

  h="";
  f="
";
  keyset=new Array();
  key=document.all.keys.value;
  if (key==""){
   alert("请输入关键字!");
   return;
  }
  else{
  keyset[0]=tempText.indexOf(key,0);
   if (keyset[0]<0){
return;
}else
temp=tempText.substring(0,keyset[0]);
temp=temp+h+key+f;
temp2=tempText.substring(keyset[0]+key.length,tempText.length);
for (i=1;i keyset[i]=tempText.indexOf(key,keyset[i-1]+key.length);
if(keyset[i]<0){
temp=temp+tempText.substring(keyset[i-1]+key.length,tempText.length);
break;
}else{
temp=temp+tempText.substring(keyset[i-1]+key.length,keyset[i])+h+key+f;
}
}
world.innerHTML = temp;
}
}

function Article_PageNav(ShowStyle,Page){
//分页码显示函数
//参数为调用样式,0=简单样式,1=标准样式
var temp="";

if (ShowStyle==0)
//简单样式
{
tempPage=Page;
if(TotalByte>PageSize){
    if (Page-4<=1){
temp=temp+"9";
     if (Page<=1){temp=temp+"7";}else{temp=temp+"7";}
     if (PageCount>10){
      for(i=1;i<8;i++){
       if (i==Page){
        temp=temp+""+i+" ";
       }else{
        temp=temp+""+i+""+" ";
       }
      }
     temp=temp+" ...";
     }
     else{
      for(i=1;i       if (i==Page){
        temp=temp+""+i+" ";
       }
       else{
        temp=temp+""+i+""+" ";
       }
      }
     }

     if (Page==PageCount){temp=temp+"8";}else{temp=temp+"8";}
     if(PageCount<10){temp=temp+":";}else{temp=temp+":";}
    }
    else if(Page+4<=PageCount){
temp=temp+"9";
    temp=temp+"7";
     if (PageCount>10){
      temp=temp+"..";
      for(i=Page-4;i       if (i==Page){
        temp=temp+""+i+" ";
       }
       else{
       temp=temp+""+i+""+" ";
       }
      }
      temp=temp+" ..";
     }
     else{
      for(i=1;i       if (i==Page){
        temp=temp+""+i+" ";
       }
       else{
       temp=temp+""+i+""+" ";
       }
      }
     }

     if (Page==PageCount){temp=temp+"8";}else{temp=temp+"8";}
     temp=temp+":";

    }
    else{
     temp=temp+"9";
     temp=temp+"7";
     temp=temp+".."

     for(i=Page-2;i      if (i==Page){
       temp=temp+""+i+" ";
      }
      else{
       temp=temp+""+i+""+" ";
      }
     }

     if (Page==PageCount){temp=temp+"8";}else{temp=temp+"8";}
     temp=temp+":";
    }
   }
   else{
    temp=temp+"1 ";
   }

   temp=temp " 显示全部"
  }
  else if (ShowStyle==1)
  //标准样式
  {
   if(TotalByte>PageSize){if(Page!=0){if(Page!=1){temp=temp "[上一页]  ";}}}
   for (i=1;i   {
    if (Page==i)
    {
     temp=temp "[" i "]  ";
    }
    else{
     temp=temp "[" i "]  ";
    }
   }
   temp=temp "";
   if(TotalByte>PageSize){if(Page!=0){if(Page!=PageCount){temp=temp "[下一页]";}}}

   temp=temp " 显示全部"
  }
  else if (ShowStyle==2)
  //下拉菜单样式
  {
   temp=temp '";
  }

  return (temp);
 }

//默认页
text_pagination(startpage);


--------------分页js代码结束--------------

------------html页面,调用分页js------------------

复制代码 代码如下:

js分页


           

border=0>
             
             
               





大家来试验分页哦~~~~~[NextPage]我分~~~[NextPage]我再分[NextPage]分分分
]]>




                 


               



Related labels:
js
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template