博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
移动端下拉刷新、上拉加载更多 Jquery插件 dropload
阅读量:7226 次
发布时间:2019-06-29

本文共 2310 字,大约阅读时间需要 7 分钟。

hot3.png

dropload

a javascript implementation of pull to refresh and up to loadmore

移动端下拉刷新、上拉加载更多插件

背景介绍 (introduce)

年前把tab例子加上来让群友测试,果然群众的力量是伟大的!立马就检测出来bug,我当即修复好,只是用法比较复杂,暂时还想不出更方便的办法。顺便把上个版本的dropReload()API删掉,功能集成到之前resetload()里。另外还修复一个朋友发现的只调用下拉刷新,代码判断bug。

最新版本 (The latest version)

0.9.0(160215)

  • 删除dropReload()API,功能集成到之前resetload()里
  • 优化noData(),noData(false)为有数据
  • 修复只调用下拉刷新,不调用上拉加载更多bug

示例 (demo)

依赖 (dependence)

Zepto 或者 jQuery 1.7以上版本,推荐jQuery 2.x版本(二者不要同时引用)

Zepto or jQuery 1.7+,recommend to use jQuery 2.x(not use them at the same time)

使用方法 (usage)

引用css和js

(basic)

$('.element').dropload({    scrollArea : window,    loadDownFn : function(me){        $.ajax({            type: 'GET',            url: 'json/more.json',            dataType: 'json',            success: function(data){                alert(data);                // 每次数据加载完,必须重置                me.resetload();            },            error: function(xhr, type){                alert('Ajax error!');                // 即使加载出错,也得重置                me.resetload();            }        });    }});

(注明:所有示例里ajax和setTimeout都是为了模拟加载效果而写的,与本插件无直接关系。ajax建议自己写,无特殊情况不必copy我的ajax写法,因为写得太烂。如需下载本地运行,请在本机装服务器环境,否则ajax会报错。)

参数列表 (options)

参数 说明 默认值 可填值
scrollArea 滑动区域 绑定元素自身 window
domUp 上方DOM {
domClass : 'dropload-up',
domRefresh : '<div class="dropload-refresh">↓下拉刷新</div>',
domUpdate : '<div class="dropload-update">↑释放更新</div>',
domLoad : '<div class="dropload-load">○加载中...</div>'
}
数组
domDown 下方DOM {
domClass : 'dropload-down',
domRefresh : '<div class="dropload-refresh">↑上拉加载更多</div>',
domLoad : '<div class="dropload-load">○加载中...</div>',
domNoData : '<div class="dropload-noData">暂无数据</div>'
}
数组
autoLoad 自动加载 true true和false
distance 拉动距离 50 数字
threshold 提前加载距离 加载区高度2/3 正整数
loadUpFn 上方function function(me){
//你的代码
me.resetload();
}
loadDownFn 下方function function(me){
//你的代码
me.resetload();
}

API

暴露一些功能,可以让dropload更灵活的使用

lock()锁定dropload

参数 说明
lock() 智能锁定,锁定上一次加载的方向
lock('up') 锁定上方
lock('down') 锁定下方

unlock()解锁dropload

noData()无数据

参数 说明
noData() 无数据
noData(true) 无数据
noData(false) 有数据

resetload()重置。每次数据加载完,必须重置

dropReload()手动加载

已知问题

  • 由于部分Android中UC和QQ浏览器头部有地址栏,并且一开始滑动页面隐藏地址栏时,无法触发scroll和resize,所以会导致部分情况无法使用。解决方案1:增加distance距离,例如DEMO2中distance:50;解决方案2:加meta使之全屏显示

例如DEMO1

转载于:https://my.oschina.net/wangnian/blog/648032

你可能感兴趣的文章
xtrabackup 安装
查看>>
一步步学习EF Core(1.DBFirst)
查看>>
php 例子 如何转换ISO8601为 utc时间
查看>>
第四次实验
查看>>
IOS UIView 03- 自定义 Collection View 布局
查看>>
instantclient的使用入门
查看>>
【数据结构作业心得】4-1 指针笔记
查看>>
oracle拼接字段用||
查看>>
rabbitmq /usr/lib/rabbitmq/bin/rabbitmq-server: line 85: erl: command not found
查看>>
编程语言学习清单
查看>>
IO流的复习笔记
查看>>
MySQL Connector Net连接vs2012问题
查看>>
LeetCode – Refresh – Merge Intervals
查看>>
UDP编程简单案例
查看>>
Exce信息提取
查看>>
基于c的简易计算器一
查看>>
POJ1995 ZOJ2150 Raising Modulo Numbers【快速模幂】
查看>>
NTT学习笔记
查看>>
online_judge_1051
查看>>
Mac与Widow下编译与运行java文件引入多个外部jar包
查看>>