纯javascript实现分页(两种方法)


Posted in Javascript onAugust 26, 2015

先给大家贴效果图:

纯javascript实现分页(两种方法)

纯javascript实现分页(两种方法)

     网上确实有很多分页的插件以及开源代码,单本是一个后台开发猿,前台css等样式还驾驭不住,所以就开始自己去写了。其实这个分页原理很简单,就是用ajax往后台传值(当前页码),后台使用limit进行分页。

     因为这是我自己第一次动手用js写分页,写的应该也不是很完美,有些公共的没有抽取出来,但是用起来还是可以的,这块代码是可以把它当做公共的分页去处理的,我就是用

这块代码写了两个稍微不同一些的分页!公共的代码抽取的也差不多,主要就是ajax后台以及返回的值不同而已,只要把总页码的值获取到,点击首页/下一页等传值正确的话,基本上分页是不会出什么问题的

纯js实现分页方法一:

废话不多说,直接上代码了!     

注:本项目是全程使用js来写的,前台的数据通过ajax进行获取,然后再进行拼装,动态加载到页面。

1.先把上一页,下一页等的代码附上(里面的值都是伪值,下面会在js里进行重新赋值的!)

<ul class="page" id="page">
  <li id="shouye" class="p-prev disabled">
   <a href='javascript:indexpage(1);'>首 页</a>
  </li>
  <li id="shangyiye" class="p-prev disabled" >
   <a href='javascript:indexpage(-1);'><i></i>上一页</a>
  </li>
  <li ><a id="one" href="javascript:void(0);" >1</a></li>
  <li><a id="two" href="javascript:void(0);" >2</a></li>
  <li><a id="three" href="javascript:void(0);" >3</a></li>
  <li class="more"><a id="five" href="javascript:void(0);" >...</a></li>
  <li><a id="fore" href="javascript:void(0);" >13855</a></li>
  <li class='p-next'>
   <a href='javascript:indexpage(-3);' onclick="jumpToPage('2','/goods/ajaxqueryGoodsList.do.html','','goodsListContainer','13855', listPageCallback);">下一页<i></i></a>
  </li>
  <li id="weiye" class='p-next'>
   <a href='javascript:void(0);' onclick="indexpage(0);">尾 页</a>
  </li>
  <li class="total">
      <span id="span_number">共13855页 到第<input type="text" id="input_number" class="page-txtbox" />页
       <input name="" value="确定" type="button" onclick="jumpToPage(jQuery('#input_number').val(),'/goods/ajaxqueryGoodsList.do.html','','goodsListContainer','13855', listPageCallback);" class="page-btn"/>
      </span>
  </li>
 </ul>

2.首先在页面放两个隐藏域,一个是当前页码,一个是总页码,总页码是页面加载完,从后台查询出来后直接附上值的,当前页码是没操作一个,就要对当前页码赋值

<input id="jiazai" type="hidden" ></input><!-- 当前页码 -->
 <input id="totalpage" type="hidden" ></input><!-- 总页码 -->

3.写一个页面加载完的function,给总页码和当前页码赋值

$(function(){
  $('#jiazai').val(1);//给当前页码进行赋值,默认为第一页
  ajaxfunction(page,arg,chipssort,'');//这个方法是抽取的ajax后台访问的方法
});

 4.抽取的ajax方法,此页面会用到好几次这个方法,所有把它收取了出来,因为页面的数据时通过ajax从后台获取到的,后台返回的是一个List集合

//抽取ajax的方法
function ajaxfunction(page,arg,chipssort,fontval){
 $.ajax({
  type:'POST',
  url:'/admin/receptionchips/showlist',//请求的url地址
  data:{
   page:page,
   sort:arg,
   chipssort:chipssort,
   fontval:fontval
  },
  dataType:'json',
  contentType:'application/x-www-form-urlencoded; charset=utf-8',
  success:function(data){
   //返回值在进行访问抽取的方法,从后台返回
   commonfunction(data);
  }
 });
}

 5.代码看到这也不是很多,最后一个了

//抽取拼串的方法
function commonfunction(data){
 $('#projectlist').find("li").remove();
  for (var i=0;i<data.length;i++ )
  { 
  /*****因为此页面是动态加载的,这里主要就是进行拼串,代码也不少,就不漏出来占空间了*****/<br>




  }<br>


//开始是分页的核心了
  if(data.length>0){
   //设置页码
   var pading = data[0].padingnum;//总页码
   $('#totalpage').val(pading);
   var page = $('#jiazai').val();//当前页
    $('#countpage').html("<b id='currentPageNo'>"+page+"</b>/"+pading+"");
    $('#span_number').html("共"+pading+"页 到第<input type='text' id='input_number' class='page-txtbox' />页<input name='' value='确定' type='button' onclick='indexpage(-2)'/goods/ajaxqueryGoodsList.do.html','','goodsListContainer','"+pading+"', listPageCallback);' class='page-btn'/>")
  }else{
   $('#countpage').html("<b id='currentPageNo'>"+0+"</b>/"+0+"");
  }
  //设置分页的底部 就是 首页 1 2 3 4 5 6 尾页
  var pading = data[0].padingnum;//总页码href="javascript:void(0);"
  var nowpage = $('#jiazai').val();//当前页
  //one two three five fore<br>


//下面代码看着是比较麻烦,但是也不难理解 全是一样的代码,只不过是加了些判断
  if(nowpage<5 ){
   $('#one').text(1);
   $('#one').attr('href','javascript:pagenum("'+1+'");');
   $('#two').text(2);
   $('#two').attr('href','javascript:pagenum("'+(2)+'");');
   $('#three').text(3);
   $('#three').attr('href','javascript:pagenum("'+(3)+'");');
   $('#five').text(4);
   $('#five').attr('href','javascript:pagenum("'+(4)+'");');
   $('#fore').text(5);
   $('#fore').attr('href','javascript:pagenum("'+(5)+'");');
   $('#five').parent().show();
   $('#fore').parent().show();
  }else{
   //alert("已经不是第五页了");
   //设置中间的为当前页
   $('#one').text(Number(nowpage)-2);
   $('#one').attr('href','javascript:indexpage("'+(Number(nowpage)-2)+'");');
   $('#two').text(Number(nowpage)-1);
   $('#two').attr('href','javascript:indexpage("'+(Number(nowpage)-1)+'");');
   $('#three').text(nowpage);
   $('#three').attr('href','javascript:indexpage("'+(nowpage)+'");');
   $('#five').parent().show();
   $('#fore').parent().show();
   //判断下一页是否超过了总页数
   if(Number(nowpage)+1>pading){
    $('#five').parent().hide();
    $('#fore').parent().hide();
   }else{
    $('#five').parent().show();
    $('#five').text(Number(nowpage)+1);
    $('#five').attr('href','javascript:indexpage("'+(Number(nowpage)+1)+'");');
   }
   //判断下一页的第二页是否超过了总页数
   if(Number(nowpage)+2>pading){
    $('#fore').parent().hide();
   }else{
    $('#fore').parent().show();
    $('#fore').text(Number(nowpage)+2);
    $('#fore').attr('href','javascript:indexpage("'+(Number(nowpage)+2)+'");');
   }
  }
  //如果总页数小于5,这块代码主要就是设置 1 2 3 4 5 这些的显示和隐藏的
  if(pading==0){
   $('#one').parent().hide();
   $('#two').parent().hide();
   $('#three').parent().hide();
   $('#five').parent().hide();
   $('#fore').parent().hide();
  }else if(pading==1){
   $('#shouye').hide();
   $('#weiye').hide();
   $('#one').parent().hide();
   $('#two').parent().hide();
   $('#three').parent().hide();
   $('#five').parent().hide();
   $('#fore').parent().hide();
  }else if(pading==2){
   $('#one').parent().show();
   $('#two').parent().show();
   $('#three').parent().hide();
   $('#five').parent().hide();
   $('#fore').parent().hide();
  }else if(pading==3){
   $('#one').parent().show();
   $('#two').parent().show();
   $('#three').parent().show();
   $('#five').parent().hide();
   $('#fore').parent().hide();
  }else if(pading==4){
   $('#one').parent().show();
   $('#two').parent().show();
   $('#three').parent().show();
   $('#five').parent().show();
   $('#fore').parent().hide();
  }else{
   $('#one').parent().show();
   $('#two').parent().show();
   $('#three').parent().show();
   $('#five').parent().show();
   $('#fore').parent().show();
  }
  //设置高亮显示的,就是是第一页时,1亮,第二页时 2亮
  $('#page a').each(function() {
   $(this).parent().removeClass("current");
   if($(this).text()==nowpage){
    $(this).parent().addClass("current");
   }
  });
  //分页完返回页面顶端
  $("html,body").animate({scrollTop:0}, 500);
  //最后,给当前页码加1
 $('#jiazai').val(Number(bianlaing)+Number(1)); 
}

纯js实现分页方法二:

function goPage(pno,psize){ 
 var itable = document.getElementById("idData"); 
 var num = itable.rows.length;//表格行数 
 var totalPage = 0;//总页数 
 var pageSize = psize;//每页显示行数 
 if((num-1)/pageSize > parseInt((num-1)/pageSize)){  
  totalPage=parseInt((num-1)/pageSize)+1;  
  }else{  
  totalPage=parseInt((num-1)/pageSize);  
  }  
 var currentPage = pno;//当前页数 
 var startRow = (currentPage - 1) * pageSize+1;//开始显示的行  
  var endRow = currentPage * pageSize+1;//结束显示的行  
  endRow = (endRow > num)? num : endRow; 
 //前三行始终显示 
 for(i=0;i<1;i++){ 
 var irow = itable.rows[i]; 
 irow.style.display = "block"; 
 } 
 for(var i=1;i<num;i++){ 
 var irow = itable.rows[i]; 
 if(i>=startRow&&i<endRow){ 
 irow.style.display = "block"; 
 }else{ 
 irow.style.display = "none"; 
 } 
 } 
  var pageEnd = document.getElementById("pageEnd"); 
  var tempStr = ""; 
  if(currentPage>1){ 
  tempStr += "<a href="/" mce_href="/""#/" onmouseout='MM_swapImgRestore()' onmouseover=/"MM_swapImage('Image69','','images/back_buttom01_dowm.jpg',1)/" onClick=/"goPage("+(currentPage-1)+","+psize+")/"><img src="/" mce_src="/""images/back_buttom01.jpg/" name='Image69' width='38' height='15' border='0' id='Image69' /></a> " 
  }else{ 
  tempStr += "<a href="/" mce_href="/""#/" onmouseout='MM_swapImgRestore()' onmouseover=/"MM_swapImage('Image69','','images/back_buttom01_dowm.jpg',1)/"><img src="/" mce_src="/""images/back_buttom01.jpg/" name='Image69' width='38' height='15' border='0' id='Image69' /></a> "; 
  } 
  for (var i = 1; i <= totalPage; i++) { 
   if (i == currentPage) { 
     tempStr += i+" "; 
   } else { 
     tempStr += "<a href="/" mce_href="/""#/" onClick=/"goPage("+(i)+","+psize+")/">"+i+"</a> " 
   } 
  } 
  if(currentPage<totalPage){ 
  tempStr += "<a href="/" mce_href="/""#/" onmouseout=/"MM_swapImgRestore()/" onmouseover=/"MM_swapImage('Image68','','images/next_buttom01_dowm.jpg',1)/" onClick=/"goPage("+(currentPage+1)+","+psize+")/"><img src="/" mce_src="/""images/next_buttom01.jpg/" name='Image68' width='38' height='15' border='0' id='Image68' /></a> "; 
  }else{ 
  tempStr += "<a href="/" mce_href="/""#/" onmouseout=/"MM_swapImgRestore()/" onmouseover=/"MM_swapImage('Image68','','images/next_buttom01_dowm.jpg',1)/"><img src="/" mce_src="/""images/next_buttom01.jpg/" name='Image68' width='38' height='15' border='0' id='Image68' /></a> "; 
  } 
  tempStr +="<a href="/" mce_href="/""#top/" onmouseout=/"MM_swapImgRestore()/" onmouseover=/"MM_swapImage('Image20','','images/top_buttom01_dowm.jpg',1)/"><img src="/" mce_src="/""images/top_buttom01.jpg/" name='Image20' width='38' height='15' border='0' id='Image20' /></a>"; 
  document.getElementById("barcon").innerHTML = tempStr; 
  } 
 var base='<%=base%>'; 
 window.onload = function(){ 
  goPage(1,10); 
 } 
<div id="barcon" name="barcon"></div>

温馨提示:js代码中上一页 下一页定义的图片根据自己需求可以改的

好了,到这里分页就完成了,如果你们需要使用的话,可能会话费一会去理解我的代码,其实代码不难,我是使用了两个小时把它写完的,只要一行一行代码看,并且自己再加注释,把这块弄过去,不出半小时绝对搞定!

好了,到此为止用两种方法给大家介绍纯js实现分页就结束了,有不明白的地方,欢迎提出,交流,共同学习进步,谢谢。

Javascript 相关文章推荐
浅析jQuery移动开发中内联按钮和分组按钮的编写
Dec 04 Javascript
jQuery链式调用与show知识浅析
May 11 Javascript
jquery实现上传文件大小类型的验证例子(推荐)
Jun 25 Javascript
jquery mobile移动端幻灯片滑动切换效果
Apr 15 Javascript
JS创建Tag标签的方法详解
Jun 09 Javascript
基于jQuery封装的分页组件
Jun 26 jQuery
基于Vue 2.0的模块化前端 UI 组件库小结
Dec 21 Javascript
Vuejs 单文件组件实例详解
Feb 09 Javascript
vue-cli 3.0 版本与3.0以下版本在搭建项目时的区别详解
Dec 11 Javascript
详解如何运行vue项目
Apr 15 Javascript
js实现AI五子棋人机大战
May 28 Javascript
微信小程序实现多行文字滚动
Nov 18 Javascript
jquery实现LED广告牌旋转系统图片切换效果代码分享
Aug 26 #Javascript
jquery实现图片水平滚动效果代码分享
Aug 26 #Javascript
jquery validate和jquery form 插件组合实现验证表单后AJAX提交
Aug 26 #Javascript
jquery实现漂亮的二级下拉菜单代码
Aug 26 #Javascript
js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)
Aug 26 #Javascript
jQuery实现的简洁下拉菜单导航效果代码
Aug 26 #Javascript
jQuery网页选项卡插件rTabs用法实例分析
Aug 26 #Javascript
You might like
php写的带缓存数据功能的mysqli类
2012/09/06 PHP
php读取csv文件并输出的方法
2015/03/14 PHP
php基本函数汇总
2015/07/09 PHP
php求今天、昨天、明天时间戳的简单实现方法
2016/07/28 PHP
PHP基于单例模式编写PDO类的方法
2016/09/13 PHP
thinkphp关于简单的权限判定方法
2017/04/03 PHP
thinkphp5+layui实现的分页样式示例
2019/10/08 PHP
javaScript call 函数的用法说明
2010/04/09 Javascript
如何正确使用javascript 来进行我们的程序开发
2014/06/23 Javascript
使用jQuery jqPlot插件绘制柱状图
2014/12/18 Javascript
js实现简单的左右两边固定广告效果实例
2015/04/10 Javascript
jQuery插件实现适用于移动端的地址选择器
2016/02/18 Javascript
使用jQuery制作Web页面遮罩层插件的实例教程
2016/05/26 Javascript
解决微信内置浏览器返回上一页强制刷新问题方法
2017/02/05 Javascript
浅谈vux之x-input使用以及源码解读
2018/11/04 Javascript
微信小程序防止多次点击跳转和防止表单组件输入内容多次验证功能(函数防抖)
2019/09/19 Javascript
[37:47]IG vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
Python基于numpy灵活定义神经网络结构的方法
2017/08/19 Python
对python调用RPC接口的实例详解
2019/01/03 Python
Python 多维List创建的问题小结
2019/01/18 Python
基于Python的PIL库学习详解
2019/05/10 Python
Python中新式类与经典类的区别详析
2019/07/10 Python
python tkinter组件摆放方式详解
2019/09/16 Python
Django 后台带有字典的列表数据与页面js交互实例
2020/04/03 Python
哈工大自然语言处理工具箱之ltp在windows10下的安装使用教程
2020/05/07 Python
Pytorch模型迁移和迁移学习,导入部分模型参数的操作
2021/03/03 Python
茵宝(Umbro)英国官方商店:英国足球服装生产商
2016/12/29 全球购物
金蝶的一道SQL笔试题
2012/12/18 面试题
.net软件工程师应聘上机试题
2015/03/10 面试题
软件工程专业推荐信
2013/10/28 职场文书
师范教师毕业鉴定
2014/01/13 职场文书
竞争性谈判邀请书
2014/02/06 职场文书
道德大讲堂实施方案
2014/05/14 职场文书
护士个人年终总结
2015/02/13 职场文书
2016年公共机构节能宣传周活动总结
2016/04/05 职场文书
CSS3 制作的彩虹按钮样式
2021/04/11 HTML / CSS