纯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 相关文章推荐
JavaScript中使用replace结合正则实现replaceAll的效果
Jun 04 Javascript
jQuery中height()方法用法实例
Dec 24 Javascript
javascript闭包概念简单解析(推荐)
Jun 03 Javascript
node.js请求HTTPS报错:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解决方法
Dec 18 Javascript
Vue.js学习之过滤器详解
Jan 22 Javascript
Vue实现virtual-dom的原理简析
Jul 10 Javascript
基于JavaScript实现微信抢红包功能
Jul 20 Javascript
vue的事件绑定与方法详解
Aug 16 Javascript
详解从Vue-router到html5的pushState
Jul 21 Javascript
Vue2.0学习系列之项目上线的方法步骤(图文)
Sep 25 Javascript
vue.js中导出Excel表格的案例分析
Jun 11 Javascript
解决vue语法会有延迟加载显现{{xxx}}的问题
Nov 14 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面向对象分析设计的61条军规小结
2010/07/17 PHP
Smarty中调用FCKeditor的方法
2014/10/27 PHP
ThinkPHP提交表单时默认自动转义的解决方法
2014/11/25 PHP
php生成PDF格式文件并且加密
2015/06/22 PHP
PHP生成推广海报的方法分享
2018/04/22 PHP
JQuery 无废话系列教程(二) jquery实战篇上
2009/06/23 Javascript
Javascript下判断是否为闰年的Datetime包
2010/10/26 Javascript
javascript操作excel生成报表全攻略
2014/05/04 Javascript
在NodeJS中启用ECMAScript 6小结(windos以及Linux)
2014/07/15 NodeJs
JavaScript对Cookie进行读写操作实例
2015/07/25 Javascript
探析浏览器执行JavaScript脚本加载与代码执行顺序
2016/01/12 Javascript
jQuery 3.0 的 setter和getter 模式详解
2016/07/11 Javascript
Angular6新特性之Angular Material
2018/12/28 Javascript
bootstrap table实现横向合并与纵向合并
2019/07/18 Javascript
VUE兄弟组件传值操作实例分析
2019/10/26 Javascript
VUE项目axios请求头更改Content-Type操作
2020/07/24 Javascript
python基于Tkinter库实现简单文本编辑器实例
2015/05/05 Python
用Python shell简化开发
2018/08/08 Python
详谈Python 窗体(tkinter)表格数据(Treeview)
2018/10/11 Python
对python操作kafka写入json数据的简单demo分享
2018/12/27 Python
对Pycharm创建py文件时自定义头部模板的方法详解
2019/02/12 Python
选择python进行数据分析的理由和优势
2019/06/25 Python
Django对数据库进行添加与更新的例子
2019/07/12 Python
Django 模型类(models.py)的定义详解
2019/07/19 Python
Python tkinter实现图片标注功能(完整代码)
2019/12/08 Python
python 将列表里的字典元素合并为一个字典实例
2020/09/01 Python
Python进行特征提取的示例代码
2020/10/15 Python
Roots加拿大官网:加拿大休闲服饰品牌
2016/10/24 全球购物
公务员培训心得体会
2013/12/28 职场文书
建筑结构施工专业推荐信
2014/02/21 职场文书
大学开学计划书
2014/04/30 职场文书
毕业生找工作求职信
2014/08/05 职场文书
医院我们的节日活动实施方案
2014/08/22 职场文书
民事诉讼代理委托书
2014/10/08 职场文书
本科毕业论文致谢怎么写
2015/05/14 职场文书
2015初一年级组工作总结
2015/07/24 职场文书