js 分页插件_vue分页组件

js 分页插件_vue分页组件一、前言:分页功能在项目中时常用到,一款可以快速实现分页功能的插件非常有必要,pagination–这款插件功能非常完美,几乎我所有项目中使用到分页的地方都会第一时间考虑到这个插件,但是其实有能力的同学最好还是使用原生的JS或者JQuery来开发分页功能,毕竟插件很多源码比较复杂,也并不是所有功能都做到尽善尽美,仅仅是提供一个方便而已。二、具体使用方法:(1)第一步,导入jq

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

一、前言:

分页功能在项目中时常用到,一款可以快速实现分页功能的插件非常有必要,pagination–这款插件功能非常完美,几乎我所有项目中使用到分页的地方都会第一时间考虑到这个插件,但是其实有能力的同学最好还是使用原生的JS或者JQuery来开发分页功能,毕竟插件很多源码比较复杂,也并不是所有功能都做到尽善尽美,仅仅是提供一个方便而已。


二、具体使用方法:

(1)第一步,导入jquery和pagination.js

<script src="jquery.js"></script>

Jetbrains全家桶1年46,售后保障稳定

<script src="jquery.pagination.js"></script>



(2)第二步,HTML代码:

非常简单只需要一个div标签

<div class="M-box"></div>



(3)第三步,  JS代码:

$('.M-box').pagination({
    pageCount:50,
    jump:true,
    coping:true,
    homePage:'首页',
    endPage:'末页',
    prevContent:'上页',
    nextContent:'下页'
});


如图所示:

js 分页插件_vue分页组件


三、核心参数方法

使用方法是:

$('.M-box').pagination({option})

option的参数如下:

pageCount 9 总页数
totalData 0 数据总条数
current 1 当前第几页
showData 0 每页显示的条数
prevCls ‘prev’ 上一页class
nextCls ‘next’ 下一页class
prevContent ‘<‘ 上一页节点内容
nextContent ‘>’ 下一页节点内容
activeCls ‘active’ 当前页选中状态class名
count 3 当前选中页前后页数
coping false 是否开启首页和末页,值为boolean
isHide false 总页数为0或1时隐藏分页控件
keepShowPN false 是否一直显示上一页下一页
homePage 首页节点内容,默认为空
endPage 尾页节点内容,默认为空
jump false 是否开启跳转到指定页数,值为boolean类型
jumpIptCls ‘jump-ipt’ 文本框内容
jumpBtnCls ‘jump-btn’ 跳转按钮class
jumpBtn ‘跳转’ 跳转按钮文本内容
callback function(){} 回调函数,参数”index”为当前页

其中回调函数是最核心的参数,即点击分页的数字按钮时所执行的操作,回调函数中有一个参数叫api

callback:function(api){

//回调函数。。。

}


该api接口的方法有如下:

方法                                参数                           说明

getPageCount()               无                         获取总页数

setPageCount(page)      page:页数           设置总页数

getCurrent()                    无                           获取当前页

filling()                             无                         填充数据,参数为页数


四、AJAX动态分页

其实做分页最主要的就是通过AJAX来动态获取数据后进行分页显示,我们要明白的是,为什么分页??

首页,因为数据库的数据是不可估量的,如果某一个系统的数据库数据有几千条甚至几万条,难道一个网页要把全部的数据都全部的展示出来吗??那肯定是不合理的,因为这非常消耗系统内存和网络带宽,我们肯定都是在AJAX请求数据时,传入了要显示的条数和页数,服务器在根据条数和页数返回数据给我们,比如我们要显示10条数据,显示第一页的内容,那服务器就相应的把该条件下的数据传回给我们,仅仅10条,这对于数据库和网页显示来说毫无压力。所以这就有了分页功能的出现。如果有50条数据,每页只显示10条数据,那理所当然的就是有5页了,那问题又来了,难道这个分页怎么知道我每个页数需要显示什么内容呢???是我全部加载数据后平均分配到每一页10条数据,然后依次显示下去吗??当然不是,我每当点击页数按钮的时候都要去加载数据,重新发起AJAX请求到服务器,然后返回数据给我们,那我们就大概知道怎么使用这个分页功能了!!


(1).首页,你得知道你分页按钮上需要显示几页吗??例如5页的话就是5个按钮。

所以首先必须使用AJAX请求得到所有数据的长度是多少,例如:  总共50条数据,我需要每页显示10条数据,当前 显示第一页的数据。

$.ajax({

url:…

type:”post”,

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//data.length  就是数据的长度 ,也就是上面的10,具体参数名看你们服务器的返回叫什么

//data.count   是数据的总长度,也就是50,具体参数名看你们服务器的返回叫什么

}

})


(2).然后我在success方法中写入pagination的方法进行分页

$.ajax({

url:…

type:”post”,

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//获取总条数
var sumCount=data
.count;

//获取返回的条数

var count=data.length;


//重要的一步来了,需要获取我们按钮的个数,也就是分多少页,需要总条数除以返回数在向上取整

var pageCount=Math.ceil(sumCount/count);  //这里50除以10等于5,所以一共有5页

$(‘.M-box’).pagination({

               pageCount:pageCount, //总页数
               coping:true,//是否开启首页和尾页
               homePage:’首页’,
               endPage:’末页’,
               prevContent:’上页’,
               nextContent:’下页’,
               current:1,  //当前第几页
               callback:function(api){  //按钮
、回调函数

}

});

}

})


(3).现在最最关键的来了,就是分页中的回调函数的操作,也就是点击按钮需要做什么??上面第四点中分析到,点击按钮需要重新发起AJAX请求,需要把显示条数和当前的页数传回给服务器

$.ajax({

url:…

type:”post”,

data:{

rows:  10  //我把行数传回给服务器中

page:1  //显示第一页的数据

}

success:function(data){

//获取总条数
var sumCount=data
.count;

//获取返回的条数

var count=data.length;


//获取分页数

var pageCount=Math.ceil(sumCount/count);  //这里50除以10等于5,所以一共有5页

$(‘.M-box’).pagination({

               pageCount:pageCount, //总页数
               coping:true,//是否开启首页和尾页
               homePage:’首页’,
               endPage:’末页’,
               prevContent:’上页’,
               nextContent:’下页’,
               current:1,  //当前第几页
               callback:function(api){  //按钮
、回调函数

//再次发起AJAX请求

$.ajax({

url:…

type:”post”,

data:{

rows: 10, //依然显示10条数据

page: api.getCurrent()// 非常关键的一步,这里就要用到api接口的方法中获取当前页

的方法了,比如我点击第二页,当前页就是2,点击第三页,

当前页就是3,

}

success:function(data){

//ajax成功后的回调。。。

}

})


}

});

}

})



以上基本的一个流程就是这样。具体一些api方法和参数可以去试试。

一个很主要的流程就是,首先要发起ajax得到总条数和返回的条数然后在success回调中使用pagination的方法,在callback回调中再次发起ajax,就是为了点击分页按钮再次显示数据


推荐pagination插件下载地址:http://download.csdn.net/detail/baidu_25343343/9822636







版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234848.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vb.net简单的计算器实现

    vb.net简单的计算器实现

    2021年3月12日
    152
  • JAVA合法标识符

    JAVA合法标识符Java语言中,对于变量,常量,函数,语句块均有名字,我们统统称之为Java标识符.标识符是用来给类、对象、方法、变量、接口和自定义数据类型命名的。标识符组成Java标识符由数字,字母和下划线(_),美元符号($)组成。此处的字母并不局限于26个英文字母,而且可以包含中文字符、日文字符等。Java语言支持Unicode6.2.0字符集,因此Java的标识符可以使用Unicode6.

    2022年7月8日
    21
  • ArrayList初始化长度

    ArrayList初始化长度每个ArrayList实例都有一个容量,该容量是指用来存储列表元素的数组的大小。它总是至少等于列表的大小。随着向ArrayList中不断添加元素,其容量也自动增长。自动增长会带来数据向新数组的重新拷贝,因此,如果可预知数据量的多少,可在构造ArrayList时指定其容量。在添加大量元素前,应用程序也可以使用ensureCapacity操作来增加ArrayList实例的容量,这可以减少递增式再分配的…

    2025年8月12日
    2
  • Tomcat全攻略

    Tomcat全攻略

    2021年12月15日
    55
  • windows部署apache_win7下ftp服务器搭建

    windows部署apache_win7下ftp服务器搭建======================更新时间2019年5月6日=====================更新内容:增加操作系统及VC++的版本要求======================更新时间2019年4月19日=====================更新内容:Apache版本更新到2.4.39,修改配置文件更加简单,只需一步。原始的2.4.2…

    2025年8月24日
    5
  • 2021数模美赛A题翻译及思路

    2021数模美赛A题翻译及思路A题懒得看了,不占坑了,可以去看看我EF的思路(还在占坑)问题A:菌类2021美赛A题思路。2021美赛A题解法。2021美赛思路,2021美赛数学建模思路,欢迎加入秀儿为你弹奏东风破:752899821碳循环描述了整个地球地球化学循环中碳交换的过程,是地球生命的重要组成部分。碳循环的一部分包括化合物的分解,使碳得以更新并以其他形式使用。该过程的这一部分的关键组成部分是植物材料和木质纤维的分解。分解木质纤维的一些关键因素是真菌。最近关于真菌通过木材分解的研究文章的作者确定了决定分解速率的真菌性状,并

    2022年5月7日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号