分页功能在项目开发中不可或缺,老司机操作起来就和呼吸一样简单,新手恐怕就会吃力一些。

今天我回顾了一下具体的操作步骤,决定详细的分析一下每一步的实现目的及原理。

我们会创建一个简单的json文件来模拟要从数据库请求的数据。

分页应注意下面几点问题:

1)  每页的条目数量,以下用show_per_page变量来表示

2)  页数的统计,总页数/show_per_page就是页数了

3)  利用a标签的href属性,指向对应的函数,就可以实现页面跳转

4)  定义a标签的一个longdisc属性,来判断哪个a标签被选中,给他添加active_page类名

HTML代码:

//用来存放目前的选中页

<input type='hidden' id='current_page' />

//存放显示的页面条数

<input type='hidden' id='show_per_page' />

//显示内容的盒子

<div id='content'>

</div>

//存放供选择页面的点击按钮

<div id='page_navigation'></div><br>

<br>

jQuery代码:

$(function(){

//一个ajax的get请求,获取要得到的数据

  $.get("get.json",function(data){

    var data=data;

//命名分页的条目数量

    var show_per_page = 5;

//获取到的数据条目数就是总的条目数量

    var number_of_items = data.list.length;

//遍历这些条目,创建p标签并添加到div里面

    var htmlStr="";

    $.each(data.list, function(index,obj) {

      htmlStr+="<p>"+obj+"</p>";

    });

    $("#content").append(htmlStr);

//显示的页数

    var number_of_pages = Math.ceil(number_of_items/show_per_page);

//选中页默认为0

    $('#current_page').val(0);

//显示页面的条数

    $('#show_per_page').val(show_per_page);

//拼接向前翻页字符串

    var navigation_html = '<a class="previous_link" href="javascript:previous();">Prev</a>';

//拼接将要显示的总页数的字符串,longdesc类似于alt标签属性,用作选中元素添加active_page类名

    var current_link = 0;

    while(number_of_pages > current_link){

navigation_html += '<a class="page_link" href="javascript:go_to_page(' + current_link +')" longdesc="' + current_link +'">'+     (current_link + 1) +'</a>';

      current_link++;

    }

//拼接向后翻页字符串

    navigation_html += '<a class="next_link" href="javascript:next();">Next</a>';

//将字符串添加到列表里

    $('#page_navigation').html(navigation_html);

//默认第一个页数按钮的class名字

    $('#page_navigation .page_link:first').addClass('active_page');

//将获取的条数全部隐藏

    $('#content').children().css('display', 'none');

//第一页显示的条数显示

    $('#content').children().slice(0, show_per_page).css('display', 'block');

  })

});

//向前翻页,回顾拼接字符串的点击跳转属性

function previous(){

  new_page = parseInt($('#current_page').val()) - 1;

//判断如果它前面有兄弟元素,即跳到前一页

  if($('.active_page').prev('.page_link').length==true){

    go_to_page(new_page);

  }

}

//向后翻页

function next(){

  new_page = parseInt($('#current_page').val()) + 1;

  //判断如果它后面有兄弟元素,即跳到后一页

  if($('.active_page').next('.page_link').length==true){

    go_to_page(new_page);

  }

}

//这才是最核心的函数,它带动每个翻页功能

function go_to_page(page_num){

  var show_per_page = parseInt($('#show_per_page').val());

  start_from = page_num * show_per_page;

  end_on = start_from + show_per_page;

//除了当前显示页面的数据显示,其余都隐藏

  $('#content').children().css('display', 'none').slice(start_from, end_on).css('display', 'block');

//当前点击的页面a按钮添加avtive_page类名,其余都移除

  $('.page_link[longdesc=' + page_num +']').addClass('active_page').siblings('.active_page').removeClass('active_page');

//最重要的一步

  $('#current_page').val(page_num);

}

这样代码就可以运行了

jQuery实现的简单分页功能的详细解析的更多相关文章

  1. DataGridView使用BindingNavigator实现简单分页功能

    接上一篇<DataGridView使用自定义控件实现简单分页功能>,本篇使用BindingNavigator来实现简单分页功能.其实也只是借用了一个BindingNavigator空壳, ...

  2. guitar pro系列教程(一):Guitar Pro主界面之记谱功能的详细解析【上】

    相信弹吉他的朋友们对guitar pro这款软件并不陌生,也有很多朋友用它来看谱制谱.而GP有很多实用功能,能够使我们看谱更清晰,制谱更便捷,所以让我们一起来看看吧 Guitar Pro对初学作曲,特 ...

  3. Django实现简单分页功能

    使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...

  4. jQuery实现的简单小功能(实用)

    1.返回顶部使用JQuery的animate和scrollTop方法可以创建简单地返回顶部的动画: // Back to top $('#top').click(function (e) { e.pr ...

  5. DataGridView使用自定义控件实现简单分页功能

    本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下: 1.新建一个自定义控件,命名为:PageControl. 2.PageControl代码如下: public part ...

  6. jQuery与直接写JS的区别详细解析

    jQuery代码具体的写法和原生的Javascript写法在执行常见操作时的区别如下所示.需要的朋友可以过来参考下     要使用jQuery,首先要在HTML代码最前面加上对jQuery库的引用,比 ...

  7. guitar pro系列教程(二):Guitar Pro主界面之记谱功能的详细解析【下】

    本章节我们接着上一章节继续讲解关于guitar pro主界面的记谱功能里的符号功能.有兴趣的朋友可以进来一起学习哦. 首先我们看下图,这是点击按钮便会弹出的一个窗口,进入这个窗口,我们会看到" ...

  8. 简单封装分页功能pageView.js

    分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...

  9. C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi

    C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...

随机推荐

  1. leaflet地图库

    an open-source JavaScript libraryfor mobile-friendly interactive maps Overview Tutorials Docs Downlo ...

  2. Anaconda 安装概要

    Anaconda 作为开源项目,集成了Python的大部分第三方包,如:pandas,Numpy,scipy等. 1. 下载地址:https://www.continuum.io/downloads ...

  3. 101个Linq的例子

    Where - Simple 1 筛选出数值中大于5的元素 public void Linq1() { int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 } ...

  4. ES6(一)let const

    1.let 声明变量 let和var区别: let 只在变量声明时所在的代码块内有效 let不允许在同一作用域内重复声明变量 let不存在变量提升 const: 也是声明一个只读常量,一旦声明,常量的 ...

  5. IOC(控制反转)

    一.容器与Bean 在Spring中,那些组成你应用程序的主体(backbone)及由Spring IoC容器所管理的对象,被称之为bean. 简单地讲,bean就是由Spring容器初始化.装配及管 ...

  6. Ubuntu操作相关笔记

    Eclipse添加图标 #sudo vim /usr/share/applications/eclipse.desktop 写入以下内容 [Desktop Entry] Name=Eclipse Co ...

  7. redis加入windows服务自启动

    今天研究了下redis,很简单 下载减压就可以用,但是自启动搞了好久! 直接sc create redis binPath = D:redis/redis-server.exe start = aut ...

  8. 两种为wangEditor添加拖拽调整高度的方式:CSS3和jQuery UI

    wangEditor是一款优秀的Web富文本编辑器,但如果能像KindEditor那样支持拖拽调整高度就更好了.有两种方式可以为wangEditor添加这一功能,这里使用的wangEditor版本为2 ...

  9. GOPS 2016全球运维大会 • 北京站概况

    GOPS 2016全球运维大会上海站已圆满落幕,错过上海站的朋友或许会感到一些遗憾,但是不用担心,在12月16日,GOPS 2016全球运维大会 • 北京站将隆重召开,错过上海在的朋友可以赶上北京站哦 ...

  10. 《JS权威指南学习总结--8.8.2高阶函数》

    内容要点: 所谓高阶函数(higher-order function)就是操作函数的函数,它接收一个或多个函数作为参数,并返回一个新函数. 例1: //这个高阶函数返回一个新的函数,这个新函数将它的实 ...