欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序实现移动端滑动分页效果(ajax)

程序员文章站 2022-04-10 11:31:14
一般在pc上我们要分页都是通过上一页和下一页来实现的,手机通过当下滑到一定程度的时候自动加载下一页面。 实现思路:首先加载部分数据,当下滑到某个元素可见的时候,如果还...

一般在pc上我们要分页都是通过上一页和下一页来实现的,手机通过当下滑到一定程度的时候自动加载下一页面。

实现思路:首先加载部分数据,当下滑到某个元素可见的时候,如果还有数据,则新发送请求,然后追加在当前页面。

/*
*<div class='topicbox' id='listbox'>
*</div>
*/
 

//判断元素是否进入可视区域 
function see(objlilast) {
 //浏览器可视区域的高度 
 var see = document.documentelement.clientheight;
 //滚动条滑动的距离 
 var winscroll = $(this).scrolltop();
 //距离浏览器顶部的 
 var lastlisee = $(objlilast).offset().top;
 return lastlisee < (see + winscroll) ? true : false;
}
//预设页码为当前第一页
var page = 1;
//获得总页码
var pagetotal = parseint($('#allpage').val());
//是否请求出ajax的“开关”; 
var onoff = true;
$(window).scroll(function () {
//拖动滚条时,是否发送ajax的一个“开关” 
$('.topicbox').each(function () {
//引用最后一个div 
var lastli = $('.topicbox:last');
//调用是否进入可视区域函数 
var issee = see(lastli);
if (issee && onoff && page < pagetotal) {//最底部元素可见,开关开启而且还有下拉
//$('#loadnext').show(); //显示正在加载图标
onoff = false;
$.ajax({
url: '/getpagedata',
type: 'get',
datatype: 'json',
data: {
page: page+1
},
asyc: false,
success: function (result) {
if (result.status == 'success') {
var data = result.result;
for (var i = 0; i < data.length; i++) {
//to do coding ...
};
}
//$('#loadnext').hide(); //隐藏正在加载
onoff = true;
page ++;
}
});

}
});
});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。