jQuery实现的简单分页功能的详细解析
分页功能在项目开发中不可或缺,老司机操作起来就和呼吸一样简单,新手恐怕就会吃力一些。
今天我回顾了一下具体的操作步骤,决定详细的分析一下每一步的实现目的及原理。
我们会创建一个简单的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实现的简单分页功能的详细解析的更多相关文章
- DataGridView使用BindingNavigator实现简单分页功能
接上一篇<DataGridView使用自定义控件实现简单分页功能>,本篇使用BindingNavigator来实现简单分页功能.其实也只是借用了一个BindingNavigator空壳, ...
- guitar pro系列教程(一):Guitar Pro主界面之记谱功能的详细解析【上】
相信弹吉他的朋友们对guitar pro这款软件并不陌生,也有很多朋友用它来看谱制谱.而GP有很多实用功能,能够使我们看谱更清晰,制谱更便捷,所以让我们一起来看看吧 Guitar Pro对初学作曲,特 ...
- Django实现简单分页功能
使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...
- jQuery实现的简单小功能(实用)
1.返回顶部使用JQuery的animate和scrollTop方法可以创建简单地返回顶部的动画: // Back to top $('#top').click(function (e) { e.pr ...
- DataGridView使用自定义控件实现简单分页功能
本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下: 1.新建一个自定义控件,命名为:PageControl. 2.PageControl代码如下: public part ...
- jQuery与直接写JS的区别详细解析
jQuery代码具体的写法和原生的Javascript写法在执行常见操作时的区别如下所示.需要的朋友可以过来参考下 要使用jQuery,首先要在HTML代码最前面加上对jQuery库的引用,比 ...
- guitar pro系列教程(二):Guitar Pro主界面之记谱功能的详细解析【下】
本章节我们接着上一章节继续讲解关于guitar pro主界面的记谱功能里的符号功能.有兴趣的朋友可以进来一起学习哦. 首先我们看下图,这是点击按钮便会弹出的一个窗口,进入这个窗口,我们会看到" ...
- 简单封装分页功能pageView.js
分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...
- C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi
C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...
随机推荐
- C#代码篇:代码产生一个csv文件调用有两个核心的坑
忙活了半天终于可以开工了,a物品到底要不要放进去取决于两个因素,第一是a有4kg重,只有背包大于等于4kg的时候才能装进去(也就是说当i=1,k<4时f[i,k]=0):第二是当背包的重量大于等 ...
- 一.Maven的安装和配置整理
Maven的安装和配置 1.1安装 进入Maven官网的下载页面:http://maven.apache.org/download.cgi选择当前最新版本:" ...
- timeit模块 与 time模块,计时的区别
time 模块,理解容易 import time time_start = time.time() time_end = time.time() time_use = time_end - time ...
- 一个初学者的辛酸路程-python操作SQLAlchemy-13
前言 其实一开始写blog,我是拒绝的,但是,没办法,没有任何理由抗拒.今天呢,要说的就是如何使用Python来操作数据库. SQLAlchemy SQLAlchemy是Python编程语言下的一款O ...
- JQuery $ $.extend(),$.fn和$.fn.extend javaScript对象、DOM对象和jQuery对象及转换 工具方法(utility)
一.为什么jquery前面要写$ Javascript没有package的概念,而作者又希望所有jQuery相关的API都能通过一个全局性的对象来容纳. 名为jQuery的全局变量就是这样一个对象,不 ...
- Python 第一课笔记
1.Hello World程序的两种方法 在windows下执行 1.编辑器里输入,不用编译 print("Hello World!") 直接就可以运行 2.可以 ...
- 记一次-angular-数字格式化
一个收费功能模块,需要做数据验证. input标签的ng-model的数据格式化 <input type="number" class="form-control& ...
- LINQ To SQL 处理 DateTime?
LINQ To SQL 处理 DateTime? 类型 例子: 搜索栏含有最后扫描时间的日期(DateTime?)与多个其他条件(String) 现在需要写一个查询 : 查询符合最后扫描的日期的查询 ...
- 【第七篇】Volley之处理Gzip数据
一般对于API请求需带上GZip压缩,因为API返回数据大都是Json串之类字符串,GZip压缩后内容大小大幅降低. public class GZipRequest extends StringRe ...
- 第14天dbutils与案例
第14天dbutils与案例 第14天dbutils与案例 1 1. 1.dbutils介绍 2 2. 2.dbutils快速入门 2 3. 3.dbutils A ...