纯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 相关文章推荐
COM中获取JavaScript数组大小的代码
Nov 22 Javascript
javascript针对DOM的应用实例(一)
Apr 15 Javascript
js 将json字符串转换为json对象的方法解析
Nov 13 Javascript
JavaScript访问字符串中单个字符的两种方法
Jul 03 Javascript
详解JavaScript逻辑And运算符
Dec 04 Javascript
Select下拉框模糊查询功能实现代码
Jul 22 Javascript
前端实现文件的断点续传(前端文件提交+后端PHP文件接收)
Nov 04 Javascript
原生js实现节日时间倒计时功能
Jan 18 Javascript
Vue 实用分页paging实例代码
Apr 12 Javascript
JavaScript事件发布/订阅模式原理与用法分析
Aug 21 Javascript
解决vue移动端适配问题
Dec 12 Javascript
jQuery 动态粒子效果示例代码
Jul 07 jQuery
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
使用Apache的rewrite技术
2006/06/22 PHP
详解PHP的Yii框架中自带的前端资源包的使用
2016/03/31 PHP
使javascript也能包含文件
2006/10/26 Javascript
javascript一点特殊用法
2008/05/28 Javascript
javascript 限制输入和粘贴(IE,firefox测试通过)
2008/11/14 Javascript
Javascript学习笔记7 原型链的原理
2010/01/11 Javascript
jquery animate图片模向滑动示例代码
2011/01/26 Javascript
imgAreaSelect 中文文档帮助说明
2011/10/08 Javascript
jquery下checked取值问题的解决方法
2012/08/09 Javascript
jQuery对象和Javascript对象之间转换的实例代码
2013/03/20 Javascript
Javascript页面添加到收藏夹的简单方法
2013/08/07 Javascript
jQuery中toggle()函数的使用实例
2015/04/17 Javascript
Bootstrap的图片轮播示例代码
2015/08/31 Javascript
基于JavaScript实现网页倒计时自动跳转代码
2015/12/28 Javascript
探究Javascript模板引擎mustache.js使用方法
2016/01/26 Javascript
JavaScript数据结构中串的表示与应用实例
2017/04/12 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
详解写好JS条件语句的5条守则
2019/02/28 Javascript
js实现拖动缓动效果
2020/01/13 Javascript
vue+flask实现视频合成功能(拖拽上传)
2021/03/04 Vue.js
解决matplotlib库show()方法不显示图片的问题
2018/05/24 Python
python Django里CSRF 对应策略详解
2019/08/05 Python
pyspark 随机森林的实现
2020/04/24 Python
Python利用Pillow(PIL)库实现验证码图片的全过程
2020/10/04 Python
html5 标签
2009/07/16 HTML / CSS
函授本科毕业自我鉴定
2013/10/09 职场文书
单位实习证明怎么写
2014/01/17 职场文书
初三家长会邀请函
2014/01/18 职场文书
银行转正自我鉴定
2014/09/29 职场文书
2014年药剂科工作总结
2014/11/26 职场文书
小学班主任评语
2014/12/29 职场文书
财政局长个人总结
2015/03/04 职场文书
留学推荐信怎么写
2015/03/26 职场文书
求职自荐信范文(优秀篇)
2015/03/27 职场文书
Python  lambda匿名函数和三元运算符
2022/04/19 Python
Android开发EditText禁止输入监听及InputFilter字符过滤
2022/06/10 Java/Android