热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

iscroll实现上拉加载下拉刷新

<!DOCTYPEhtml><html><head><metacharsetUTF-8><meta









— 下 拉 刷 新 —



下拉刷新





上拉加载更多



— 上 拉 加 载 —





 //css样式

* {margin: 0;padding: 0; }

header, footer {width:
100%;height: 40px;line-height: 40px;background: #EEEEEE;text-align: center;font-size: 18px;font-weight: 600; position: absolute;left: 0; }

header {top:
0; }

footer {bottom:
0; }

section {overflow
-y: scroll;background: lightskyblue;position: absolute;top: 40px;bottom: 40px;width: 100%; }
section ul {padding: 5px; }
section ul li {background: #FFFFFF;margin
-bottom: 10px;text-align: center;line-height: 36px;list-style: none; }
#scroller {position: absolute;top:
-30px;left: 0;width: 100%; }
#scroller #pullDown, #scroller #pullUp {padding:
0 10px;height: 30px;line-height: 30px;color: #888;text-align: center; }

//js代码

var myScroll, pullDownEl, pullDownOffset, pullUpEl, pullUpOffset, generatedCount = 0;
loaded();
//根据下拉距离更改内容
init(); // 初始化页面内容
function pullDownAction() {
setTimeout(function () {
//do init
console.log('刷新完成');
myScroll.refresh();
},
1000)
}
function pullUpAction() {
var wrap =document.getElementById('list')
for(var i=0;i<5;i++){
var newli = document.createElement('li');
newli.innerHTML
= '加载数据--' + (++generatedCount);
wrap.appendChild(newli)
}
myScroll.refresh()
}
function init(){
var wrap =document.getElementById('list')
for(var i=0;i<10;i++){
var newli = document.createElement('li');
newli.innerHTML
= '初始数据--' + (++generatedCount);
wrap.appendChild(newli, wrap.childNodes[
0])
}
myScroll.refresh()
}
function loaded(){
pullDownEl
= document.getElementById('pullDown');
pullUpEl
= document.getElementById('pullUp');
pullDownOffset
= pullDownEl.offsetTop;
pullUpOffset
= pullUpEl.offsetTop;
myScroll
= new iScroll('wrapper',{
topOffset: pullDownOffset,
onScrollMove: function () {
if(this.y > 40 && !pullDownEl.className.match('flip')){
pullDownEl.className
= 'flip';
pullDownEl.querySelector(
".pullDownLabel").innerHTML = "释放刷新";
}
else if(this.y <this.maxScrollY && !pullUpEl.className.match('flip')){
pullUpEl.className
= 'flip';
pullUpEl.querySelector(
".pullUpLabel").innerHTML = "释放刷新";
}

}
,
onScrollEnd: function () {
if (pullDownEl.className.match("flip")) {
pullDownEl.className
= "loading";
pullDownEl.querySelector(
".pullDownLabel").innerHTML = "正在加载";
pullDownAction();
}
else if(pullUpEl.className.match("flip")){
pullUpEl.className
= "loading";
pullUpEl.querySelector(
".pullUpLabel").innerHTML = "正在加载";
pullUpAction();
}
},
onRefresh: function () {
if (pullDownEl.className.match("loading")) {
pullDownEl.className
= "";
pullDownEl.querySelector(
".pullDownLabel").innerHTML = "下拉刷新";
}
else if(pullUpEl.className.match("loading")){
pullUpEl.className
= "";
pullUpEl.querySelector(
".pullUpLabel").innerHTML = "加载更多";
}
}
})
console.log(myScroll)
}

 


推荐阅读
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 解决网站乱码问题的综合指南
    本文总结了导致网站乱码的常见原因,并提供了详细的解决方案,包括文件编码、HTML元标签设置、服务器响应头配置、数据库字符集调整以及PHP与MySQL交互时的编码处理。 ... [详细]
author-avatar
黛萊美文婷
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有