纯JavaScript实现的分页插件实例


Posted in Javascript onJuly 14, 2015

本文实例讲述了纯JavaScript实现的分页插件。分享给大家供大家参考。具体如下:

//总条数(必填)
var Num=Number(<?php echo $count;?>)
//当前页(必填)
var index = Number(<?php echo $page;?>);
/* //每页的条数(可选,默认每页10条) */
var pageNum=Number(10); 
/* //最大显示的页码的数目(可选,默认显示5个页码,页码数目必须大于等于1) */
var maxPageNum=Number(5);
//以下可忽略
//计算得出总页数
var count = (Num%pageNum)>0?(Num/pageNum+1):(Num/pageNum);
count=Math.floor(count);//取整转化为数据类型
//显示的最小页码,
var first=1;
//显示的最大页码,首先last<=count;其次last是小于等于count的最大数//last=index+maxPageNum/2;
var last =1;
var decrease=Math.floor(maxPageNum/2);//当前页向上增加值
var increase=Math.floor(maxPageNum/2);//当前页向下减少值
if(maxPageNum>=1){
 if(maxPageNum==1){//最多显示一页时
  first=index<=count?index:count; 
  last=index<=count?index:count;  
 }else{
   //first要大于零
   first=(index-decrease);
   while(first<=0){
    first++;
   } 
   //first判断显示的最后一页
   if((count-index)<=decrease){
    var diff=count-first;
    while(diff<maxPageNum-1){
     if(first==1){
      break;
     }else{
      --first;
      diff=count-first;
     }
    }
   }
   //last要小于count
   last=(index+increase);
   while(last>=1){
    if(last<=count){
     break;
    }
    last--;
   } 
   //last//判断显示的最后一页与maxPageNum的关系
   last=last>=maxPageNum?last:(maxPageNum>count?count:maxPageNum);
 }
}else{
 alert("至少需要显示一个页码!");
}
var prev = index - 1;//上一页
var next = index+ 1;//下一页 
var str = "<tr>";
if(count==0){
 str += "<td>共<a href='#'>0</a>页</td><td>";
}else if(index>count||index<=0){
 str="<td style='color:blue;' >页码超出范围</td>";
}else if (count > 0) {
 str += "<td>";
 if(first>1){
  str += "  <span style='color:#4169E1;' >...</span>  ";
 }
 var i=1;
 for(i=first;i<=last; i++){
  if(i==index){
   str += "  <a href='#' style='color:#4169E1;' onclick='submit(" + i + ");'>[" + i+ "]</a>  ";
  }else{
   str += "  <a href='#' onclick='submit(" + i + ");'>" + i+ "</a>  ";
  }
 } 
  if(last<count){
   str += "  <span style='font-size:16px;color:#4169E1;' >...</span>  "; 
  }
  str+="</td><td style='font-size: 14px;'>共<a href='#first' style='color:#4169E1;font-size: 16px;' >"+ Num +"</a>条</td>";
  /* if(index!=1){
   str +="<td style='width:60px;font-family: 微软雅黑;font-size: 14px;' ><a href='#' id='prev' onclick='submit(" + prev+ ");'>上一页</a></td>"; 
  }
  if(index<count){
   str +="<td style='width:60px;font-family: 微软雅黑;font-size: 14px;'><a href='#' id='next' onclick='submit("+ next + ");'>下一页</a></td>";
  }*/
  if(index!=1&&count>1){
   str += "<td style='width:40px;font-family: 微软雅黑;font-size: 14px;white-space: nowrap;'>  <a href='#' id='first' name='first' onclick='submit(1);'>首页</a>  </td>";
  }
  if(index!=count&&count>1&&index<count){
   str += "<td style='width:40px;font-family: 微软雅黑;font-size: 14px;white-space: nowrap;'>  <a href='#' onclick='submit(" + count+ ");'>尾页</a>  </td>" ;
  } 
   str+="</tr>";
}
//分页区域填写
$('.page').html(str);
<table class="page">
<tr><td>此处分页只需要传递给我当前页码和总页数即可</td></tr>
</table>
//根据页码查询,
function submit(pageIndex) {
 //var sortInfo = $.getUrlParam('sortInfo');//判断是哪一个页面的查询
 var url = "<?php echo current_url();?>?page="+pageIndex+"&field=<?php echo$field;?>&value=<?php echo $field_value;?>";
 window.location.href=url;
}

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
摘自启点的main.js
Apr 20 Javascript
JS在textarea光标处插入文本的小例子
Mar 22 Javascript
jQuery源码解读之hasClass()方法分析
Feb 20 Javascript
Vue中使用vee-validate表单验证的方法
May 09 Javascript
Vue递归实现树形菜单方法实例
Nov 06 Javascript
详解javascript 变量提升(Hoisting)
Mar 12 Javascript
详解vue的数据劫持以及操作数组的坑
Apr 18 Javascript
js中let能否完全替代IIFE
Jun 15 Javascript
wx-charts 微信小程序图表插件的具体使用
Aug 18 Javascript
d3.js实现图形拖拽
Dec 19 Javascript
JavaScript中的this原理及6种常见使用场景详解
Feb 14 Javascript
js实现简易计算器小功能
Nov 18 Javascript
javascript实现网页字符定位的方法
Jul 14 #Javascript
JavaScript取得WEB安全颜色列表的方法
Jul 14 #Javascript
jquery获得当前html页面源码的方法
Jul 14 #Javascript
javascript实现动态表头及表列的展现方法
Jul 14 #Javascript
浅谈JSON.parse()和JSON.stringify()
Jul 14 #Javascript
常用jQuery代码分享
Jul 14 #Javascript
jQuery插件datalist实现很好看的input下拉列表
Jul 14 #Javascript
You might like
PHP的FTP学习(三)
2006/10/09 PHP
PHP循环获取GET和POST值的代码
2008/04/09 PHP
php读取目录及子目录下所有文件名的方法
2014/10/20 PHP
PHP中的正则表达式实例详解
2017/04/25 PHP
php nginx 实时输出的简单实现方法
2018/01/21 PHP
PHP设计模式之策略模式原理与用法实例分析
2019/04/04 PHP
Jquery Ajax请求代码(2)
2011/01/07 Javascript
使用jquery为table动态添加行的实现代码
2011/03/30 Javascript
25个非常棒的jQuery滑块插件和教程小结
2011/09/02 Javascript
基于jquery实现状态限定编辑的代码
2012/02/11 Javascript
Js实现当前点击a标签变色突出显示其他a标签回复原色
2013/11/27 Javascript
教你如何在 Javascript 文件里使用 .Net MVC Razor 语法
2014/07/23 Javascript
自学实现angularjs依赖注入
2016/12/20 Javascript
使用bootstrap-paginator.js 分页来进行ajax 异步分页请求示例
2017/03/09 Javascript
解决Vue中引入swiper,在数据渲染的时候,发生不滑动的问题
2018/09/27 Javascript
js实现延迟加载的几种方法详解
2019/01/19 Javascript
elementUI select组件value值注意事项详解
2019/05/29 Javascript
详解微信小程序开发(项目从零开始)
2019/06/06 Javascript
Javascript柯里化实现原理及作用解析
2020/10/22 Javascript
[42:32]Secret vs Optic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python使用any判断一个对象是否为空的方法
2014/11/19 Python
在arcgis使用python脚本进行字段计算时是如何解决中文问题的
2015/10/18 Python
Python模拟登录验证码(代码简单)
2016/02/06 Python
python解决js文件utf-8编码乱码问题(推荐)
2018/05/02 Python
python 实现PIL模块在图片画线写字
2020/05/16 Python
css 元素选择器的简单实例
2016/05/23 HTML / CSS
阿玛尼美国官方网站:Armani.com
2016/11/25 全球购物
老公给老婆的道歉信
2014/01/10 职场文书
写给老师的表扬信
2014/01/21 职场文书
食品流通安全承诺书
2014/05/22 职场文书
居委会四风问题个人对照检查材料
2014/09/25 职场文书
如何签定毕业生就业协议书
2014/09/28 职场文书
2015年材料员工作总结
2015/04/30 职场文书
2015中学教学工作总结
2015/07/22 职场文书
小学班级管理心得体会
2016/01/07 职场文书
2019年圣诞节祝福语集锦
2019/12/25 职场文书