H5页面下拉加载更多(实用版)
近期在做一个H5网站,需要下拉加载更多产品列表的功能。百度搜索了好久,什么说法都有,什么插件都有。 醉了。基本上每一个能直接拿来用的。
最后发现:
1、dropload.js 插件 还可以,但是有个问题,只能单页使用比较方便。带有tab标签的不推荐使用。
2、自己百度了半天总结出来的一套:
<script>
document.addEventListener('scroll', watchScroll);
var itemIndex = 0;
var classid = 10;
var isloading = 0;//防止无限滚动加载
var page = $("#page").val();//页码
loadDataDynamic();//加载数据
$(function () {
$('.tab').bind('click', function () {// tab导航绑定点击事件
document.body.scrollTop = 0;//首先复位顶部
var $this = $(this);
itemIndex = $this.index();
$this.addClass('weui_bar_item_on c_f8').siblings('.tab').removeClass('weui_bar_item_on c_f8');//添加选中样式
$('.itme').eq(itemIndex).show().siblings('.itme').hide(); //切换显示div
classid = this.attributes.dataid.value;
page = 1;//页数复位
loadDataDynamic();
});
}); //加载数据
function loadDataDynamic() {
//先显示正在加载中
if ($("#loadingLi").length === 0)
$(".itme:visible>ul").append("<p id='loadingLi' class='loading'>正在加载...</p>");
else {
$("#loadingLi").text("正在加载...").removeClass("space");
}
var loadingLi = document.getElementById("loadingLi"); var msg = "";
$.ajax({
url: "/Handler/xxx.aspx?cmd=GetGameListByClass",
type: "get",
async:false,
data: { classid: classid, page: page },
dataType: "json",
beforeSend: function () { isloading = 1; },
success: function (data) {
if (data.r) {
//这边根据自己的展示需求来 修改一下。
if (page == "1") {
// 插入数据到页面
$('.itme:visible>ul').html(decodeURIComponent(data.r));
msg = "数据已加载到底了.";
} else {
$('.itme:visible>ul').append(decodeURIComponent(data.r));
}
$("#page").val(page++);
isloading = 0;
} else {
$(".itme:visible>ul").scrollTop(document.body.scrollTop - 20);
if (page == 1) {
$(".itme:visible>ul").html("<div class=\"zwsj\" ><p>暂无数据</p></div>");
} else {
msg = "数据已加载到底了";
}
}
$(".itme:visible>ul").append(loadingLi);
},
error: function (xmlHttpRequest, textStatus, errorThrown) {
msg = "数据加载失败!";
}, complete: function () {
if (page > 1) {
$("#loadingLi").text(msg);
} else {
$("#loadingLi").text("");
}
}
});
} //如果滚动条滚动到页面底部,需要加载新的数据,并且显示加载提示
function watchScroll() {
if (!isScrollToPageBottom()) {
return;
}
loadDataDynamic();
}
//作为一个对象的w和h属性返回视口的尺寸
function getViewportSize(w) {
//使用指定的窗口, 如果不带参数则使用当前窗口
w = w || window;
//除了IE8及更早的版本以外,其他浏览器都能用
if (w.innerWidth != null)
return { w: w.innerWidth, h: w.innerHeight };
//对标准模式下的IE(或任意浏览器)
var d = w.document;
if (document.compatMode == "CSS1Compat")
return { w: d.documentElement.clientWidth, h: d.documentElement.clientHeight }; //对怪异模式下的浏览器
return { w: d.body.clientWidth, h: d.body.clientHeight };
}
//检测滚动条是否滚动到页面底部
function isScrollToPageBottom() {
//文档高度
var documentHeight = document.documentElement.offsetHeight;
var viewPortHeight = getViewportSize().h;
var scrollHeight = window.pageYOffset ||
document.documentElement.scrollTop ||
document.body.scrollTop || 0; return (documentHeight - viewPortHeight - scrollHeight < 20)&& isloading == 0;//这个蛮重要的
}
</script>
写的有不足的地方可以指出来,后期优化。
效果图展示: 真实案例
参考来源 : http://www.cnblogs.com/w-wanglei/p/5863387.html
H5页面下拉加载更多(实用版)的更多相关文章
- H5 页面下拉加载更多
1.html页面: <body onload="index_roll()"> ... </body> 2.js <script type=" ...
- ASP.NET仿新浪微博下拉加载更多数据瀑布流效果
闲来无事,琢磨着写点东西.貌似页面下拉加载数据,瀑布流的效果很火,各个网站都能见到各式各样的展示效果,原理大同小异.于是乎,决定自己写一写这个效果,希望能给比我还菜的菜鸟们一点参考价值. 在开始之前, ...
- jquery实现下拉加载更多
下拉加载更多这种原理很容易想明白,但是不自己写一个简单的,老是不踏实,获取什么高度再哪里获取之类的.于是自己简单写了个,就是页面上有几个div,然后当滚动条拉到某个位置的时候,再继续加载div.顺便又 ...
- 下拉加载更多DEMO(js实现)
项目的一个前端页面展示已购买商品时,要求能下拉加载更多.花了点时间研究这个功能,以前没做过. 首先需要给div加scroll事件,监听滚动条滚动动作.那何时触发加载动作呢?当滚动条滚到底的时候.如何判 ...
- 微信小程序实现上拉和下拉加载更多
在上一篇文章中,我们知道了使用 scroll-view 可以实现上拉加载更多,但是由于 scroll-view 的限制,它无法实现下拉加载更多,这篇文章我们使用 view 组件来实现 上拉和下拉加载更 ...
- Windows Phone 8.1开发:如何让ListView下拉加载更多?
Windows Phone 8.1开发中使用ListView作为数据呈现载体时,经常需要一个下拉(拇指向上滑动)加载更多的交互操作.如何完成这一操作呢?下面为您阐述. 思路是这样的: 1.在ListV ...
- iscroll.js实现上拉刷新,下拉加载更多,应用技巧项目实战
上拉刷新,下拉加载更多...仿原生的效果----iscroll是一款做滚动效果的插件,具体介绍我就不废话,看官方文档,我只写下我项目开发的一些用到的用法: (如果不好使,调试你的css,想必是个很蛋疼 ...
- dropload.js下拉加载更多
项目中有用到下拉加载更多的地方,去网上找了一个插件,地址:http://ons.me/526.html总体还是不错的,可能自己不是特别了解这个插件,做项目时,也是遇到了无数问题.项目中要用的是两个ta ...
- JQ下拉加载更多
<!DOCTYPE=html> <html> <head> <script src="jquery-1.4.2.min.js" type= ...
随机推荐
- cdoj1580 简单图论问题
地址:http://acm.uestc.edu.cn/#/problem/show/1580 题目: 简单图论问题 Time Limit: 3000/1000MS (Java/Others) ...
- 【转】阿里巴巴技术专家杨晓明:基于Hadoop技术进行地理空间分析
转自:http://www.csdn.net/article/2015-01-23/2823687-geographic-space-base-Hadoop [编者按]交通领域正产生着海量的车辆位置点 ...
- IDEA创建Spring Boot的项目
IDEA创建SpringBoot的项目非常的方便智能,可以实现零配置,只需要在创建的时候勾选你需要的功能,比如mybatis,mysql等等,它会帮你自动下载导入响应的jar,不用自己再去手动填写. ...
- NC学习笔记
NC基础技术 一.NC开发基本概念 1.单据:一般是由表头,表体,表位组成. 表头:一般是一些主信息,例如日期,项目等 ...
- linux上使用wget下载文件
首次安装的centos操作系统是没有安装wget的,所以首先需要先安装wget,然后才能使用wget下载文件. 1.第一步,保证centos能正常连网.使用命令 :yum -y install wg ...
- centos上安装redmine
1.下载bitnami的redmine安装包 https://bitnami.com/stack/redmine/installer 2.安装remine ./bitnami-redmine-3.3. ...
- Linux中LVM2原理
一.LVM原理 [MD]:Multi Device 多设备 Mdadm是一个用户空间工具,是RAID的管理工具,与真正的RAID工作没有太大关系.真正的RAID集成在linux内核中 [DM]Devi ...
- zookeeper和淘宝dubbo的关系
Dubbo建议使用Zookeeper作为服务的注册中心. 1. Zookeeper的作用: zookeeper用来注册服务和进行负载均衡,哪一个服务由哪一个机器来提供必需让调用者知 ...
- 20145302张薇《Java程序设计》第九周学习总结
20145302 <Java程序设计>第九周学习总结 教材学习内容总结 第十六周 JDBC简介 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC目的:让Jav ...
- mybatis关联配置(一对多配置)
敲代码也有不少日子了,今天碰到个需求,就是定时器生成一张表,但是这个表的某些数据是从另外两张表中拿到的,定外两张表又是一对多的关系,想着咋在一个接口就能敲出来,大概结构如下 然后需要a表的数据(比如张 ...