iScroll使用
新公司比较喜欢用iScroll,而我对此一无所知,特此调研iScroll用法,写在这里方便查看
IScroll是移动页面上被使用的一款仿系统滚动插件。
myScroll = new IScroll("#wrapper",{
probeType: 3,
// momentum: false,//关闭惯性滑动
mouseWheel: true,//鼠标滑轮开启
scrollbars: true,//滚动条可见
fadeScrollbars: true,//滚动条渐隐
interactiveScrollbars: true,//滚动条可拖动
shrinkScrollbars: 'scale', // 当滚动边界之外的滚动条是由少量的收缩
useTransform: true,//CSS转化
useTransition: true,//CSS过渡
bounce: true,//反弹
freeScroll: false,//只能在一个方向上滑动
startX: 0,
startY: 0,
// snap: "li",//以 li 为单位
});
myScroll.on('scroll',positionJudge);
myScroll.on("scrollEnd",action);
解释:
document.addEventListener('touchmove', function (e) {
e.preventDefault();
}, false);
是iScroll的初始化
myScroll.on('scroll',positionJudge);
myScroll.on("scrollEnd",action);
对开始拖动和拖动结束的监听,这是iScroll5的一个坑,positionJudge和action都是function,但是如果直接以function(){}的方式写在里面的话,调用会出问题,所以要单独写在外面
关于IScroll下拉刷新
//下拉刷新
var myScroll = new IScroll('#wrapper', { probeType: 3, mouseWheel: true, click: true }); myScroll.on("slideDown",function(){
var y = this.y
if(this.y > 140){
window.location.reload();//刷新当前页面
}
});
IScroll最简单的DOM结构:
- <div id="wrapper">
- <ul>
- <li>...</li>
- <li>...</li>
- ...
- </ul>
- </div>
初始化iscroll
- var myScroll = new IScroll('#wrapper',options);
初始化设置
初始化设置使用实例:
- var myScroll = new IScroll('#wrapper', {
- mouseWheel: true,
- scrollbars: true
- });
设置列表:(从API直接copy过来的)
所属 |
属性名 |
说明 |
默认值 |
核心库 croe |
options.useTransform |
是否使用CSS3的Transform属性 |
true |
options.useTransition |
是否使用CSS3的Transition属性,否则使用requestAnimationFram代替 |
true |
|
options.HWCompositing |
是否启用硬件加速 |
true |
|
options.bounce |
是否启用弹力动画效果,关掉可以加速 |
true |
|
基础特性 Basic features |
options.click |
是否启用click事件。建议关闭此选项并启用自定义的tap事件(options.tap) |
false |
options.disableMouse |
是否关闭鼠标事件探测。如知道运行在哪个平台,可以开启它来加速。 |
false |
|
options.disablePointer |
是否关闭指针事件探测。如知道运行在哪个平台,可以开启它来加速。 |
false |
|
options.disableTouch |
是否关闭触摸事件探测。如知道运行在哪个平台,可以开启它来加速。 |
false |
|
options.eventPassthrough |
使用IScroll的横轴滚动时,如想使用系统立轴滚动并在横轴上生效,请开启。 |
false |
|
options.freeScroll |
主要在上下左右滚动都生效时使用,可以向任意方向滚动。 |
false |
|
options.keyBindings |
绑定按键事件。 |
false |
|
options.invertWheelDirection |
反向鼠标滚轮。 |
false |
|
options.momentum |
是否开启动量动画,关闭可以提升效率。 |
true |
|
options.mouseWheel |
是否监听鼠标滚轮事件。 |
false |
|
options.preventDefault |
是否屏蔽默认事件。 |
true |
|
options.scrollbars |
是否显示默认滚动条 |
false |
|
options.scrollX options.scrollY |
可以设置是否显示横向或纵向滚动条 |
scrollX false scrollY true |
|
options.tap |
是否启用自定义的tap事件 可以自定义tap事件名 |
false |
|
滚动条 Scrollbars |
options.scrollbars |
是否显示默认滚动条 |
false |
options.fadeScrollbars |
是否渐隐滚动条,关掉可以加速 |
true |
|
options.interactiveScrollbars |
用户是否可以拖动滚动条 |
false |
|
options.resizeScrollbars |
是否固定滚动条大小,建议自定义滚动条时可开启。 |
false |
|
options.shrinkScrollbars |
滚动超出滚动边界时,是否收缩滚动条。 ‘clip’:裁剪超出的滚动条 ‘scale’:按比例的收缩滚动条(占用CPU资源) false:不收缩, |
false |
|
options.indicators |
指示IScroll该如何滚动,Scrollbars的底层实现方式。 |
||
options.indicators.el |
制定滚动条的容器。容器中的第一个元素即为指示器。 例如: indicators: { el: document.getElementById('indicator') } indicators: { el: '#indicator' } |
||
options.indicators.ignoreBoundaries |
是否忽略容器边界。设为true 可以设置滚动速度 |
false |
|
options.indicators.listenX options.indicators.listenY |
指示器监听那个方向的滚动,可以设置为一个方向或2个方向 |
true |
|
options.indicators.speedRatioX options.indicators.speedRatioY |
指示器相对主滚动条的速度 |
0 |
|
options.indicators.fade options.indicators.interactive options.indicators.resize options.indicators.shrink |
如scrollbars的设置 |
||
options.probeType |
需要使用iscroll-probe.js才能生效 probeType:1 滚动不繁忙的时候触发 probeType:2 滚动时每隔一定时间触发 probeType:3 每滚动一像素触发一次 |
||
分割页面snap |
options.snap |
自动分割容器,用于制作走马灯效果等。 Options.snap:true//根据容器尺寸自动分割 Options.snap:el//根据元素分割 |
false |
缩放 zoom |
options.zoom |
是否打开缩放 最好使用iscroll-zoom.js 如放大模糊,可将源容器定义为2倍大小,然后scale(0.5) |
false |
options.zoomMax |
最大缩放等级 |
4 |
|
options.zoomMin |
最小缩放等级 |
1 |
|
options.startZoom |
初始缩放等级 |
1 |
|
options.wheelAction |
滚轮动作 设为’zoom’,可以用滚轮缩放 |
undefined |
|
更多设置 |
options.bindToWrapper |
光标、触摸超出容器时,是否停止滚动 |
false |
options.bounceEasing |
弹力动画效果 预置效果:'quadratic', 'circular', 'back', 'bounce', 'elastic'(最后两个不能通过css3表现) 还可以自定义效果 bounceEasing: { style: 'cubic-bezier(0,0,1,1)',//css3时 fn: function (k) { return k; }//不使用css3,使用requestAnimationFrame时 } |
'circular' |
|
options.bounceTime |
弹力动画持续的毫秒数 |
600 |
|
options.deceleration |
滚动动量减速 越大越快,建议不大于0.01 |
0.0006 |
|
options.mouseWheelSpeed |
鼠标滚轮速度 |
||
options.preventDefaultException |
列出哪些元素不屏蔽默认事件; |
{tagName: /^(INPUT|TEXTAREA|BUTTON|SELECT)$/ } |
|
options.resizePolling |
重新调整窗口大小时,重新计算IScroll的时间间隔 |
60 |
|
键位绑定 |
options.keyBindings |
监听按键事件控制IScroll 例如: keyBindings: { pageUp: 33, pageDown: 34, end: 35, home: 36, left: 37, up: 38, right: 39, down: 40 } |
|
IScroll5的API:
所属 |
方法名 |
说明 |
滚动 |
scrollTo(x, y, time, easing) |
滚动到:x,y,事件,easing方式 x:int y:int time:int Easing: quadratic | circular | back | bounce | elastic 见IScroll.utils.ease 对象 例: myScroll.scrollTo(0, -100, 1000, IScroll.utils.ease.elastic); |
scrollBy(x, y, time, easing) |
滚动到相对于当前位置的某处 其余同上 |
|
scrollToElement(el, time, offsetX, offsetY, easing) |
滚动到某个元素。el为必须的参数 offsetX/offsetY:相对于el元素的位移。设为true即为屏幕中心 |
|
分割页面snap |
goToPage(x, y, time, easing) |
根据options.snap分割页面,跳转到横向、纵向某页。XY可以同时生效。 结合options.snap使用 |
next() prev() |
上一页,下一页 结合options.snap使用 |
|
缩放 |
zoom(scale, x, y, time) |
缩放容器 Scale:缩放因子 |
刷新 |
refresh() |
刷新IScroll |
销毁 |
destroy() |
销毁IScroll,节省资源 |
应用实例:
hml结构:
<div id="wrapper">
<div id="scroller">
内容区域
</div>
</div>
CSS样式:
#wrapper{
width:750px;
position:absolute;
z-index:1;
top:0px;
bottom:0px;
left:0;
overflow:hidden;
}
#scroller{
position:absolute;
z-index:1;
width:100%;
transform:translateZ(0);
user-select:none;
text-size-adjust:none
}
//这个是下拉时候 刷新的过渡效果
.loading{
width:750px;
text-align:center;
position:absolute;
top:-140px;
}
JS结构
$(function(){
var myScroll = new IScroll('#wrapper', { probeType: 3, mouseWheel: true, click: true }); myScroll.on("slideDown",function(){
var y = this.y ;
if(this.y > 140){
window.location.reload();//刷新当前页面
}
}); myScroll.on("slideUp",function(){
if(this.maxScrollY - this.y > 40){
alert("向上刷新,请求接口数据") 这里进行ajax请求
}
}); })
当出现上下滑动的时候
iScroll使用的更多相关文章
- 【IScroll深入学习】解决IScroll疑难杂症
前言 在去年,我们对IScroll的源码进行了学习,并且分离出了一段代码自己使用,在使用学习过程中发现几个致命问题: ① 光标移位 ② 文本框找不到(先让文本框获取焦点,再滑动一下,输入文字便可重现) ...
- 使用 iscroll 实现焦点图无限循环
现在大家应该都看到过焦点图轮播的效果,这个效果是什么样我就不截图了.昨天做练习,练习要求是使用iscroll实现焦点图的无限循环滚动,并且当手指触摸焦点图后,停止焦点图的循环滚动.第一次接触iscro ...
- iscroll.js 下拉刷新和上拉加载
html代码如下 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- H5基于iScroll实现下拉刷新,上拉加载更多
前言 前一段有个手机端的项目需要用到下拉刷新和上拉加载更多的效果,脑海里第一反映就是微博那种效果,刚开始的理解有些偏差,以为下拉也是追加数据,上拉也是追加数据,后请教同事后发现其实下拉只是刷新最新数据 ...
- iscroll总结
iScroll基本信息 官网:http://cubiq.org/iscroll-4 更新:2012.07.14 版本:v4.2.5 兼容:iPhone/Ipod touch >=3.1.1, i ...
- iscroll
在原生APP的开发中,有一个常见的功能,就是下拉刷新的功能,这个想必大家都是知道的,但是原生APP的开发,有一个很大的问题就是,你每次更新一些功能,就要用户重新下载一次版本,尤其是在iOS系统中,新版 ...
- 【IScroll深入学习】突破移动端黑暗的利器(上)
前言 在去年,我们对IScroll的源码进行了学习,并且分离出了一段代码自己使用,在使用学习过程中发现几个致命问题: ① 光标移位 ② 文本框找不到(先让文本框获取焦点,再滑动一下,输入文字便可重现) ...
- 滚动条美化实践(原生js,iscroll,nicescroll)
近期需要改造项目中的滚动条,使原滚动条在三大浏览器下表现相同,分享一下自己的改造经历: 项目中的滚动条分布在网页的各个小窗口中,使用的是-webkit-scrollbar制作,在-webkit内核的浏 ...
- jquery——移动端滚动条插件iScroll.js
官网:http://cubiq.org/iscroll-5 demo: 滚动刷新:http://cubiq.org/dropbox/iscroll4/examples/pull-to-refresh/ ...
- iscroll 加载不全解决方案
例如上图中,get_kaijiang 中如果执行一段ajax跨域传输的话 function get_kaijiang(){ ajax------- $('#div').append(html); -- ...
随机推荐
- js 保留小数位数
eg: var num=3.1415926 小数位处理:num.toFixed(n) n:小数位数
- [转]操作xml,将xml数据显示到treeview的C#代码
XmlDocument xml = new XmlDocument(); private void Form1_Load(object sender, EventArgs e) { CreateXML ...
- 如何在Webstorm中添加js库 (青瓷H5游戏引擎)
js等动态语言编码最大的缺点就是没有智能补全代码,webstorm做到了. qici_engine作为开发使用的库,如果能智能解析成提示再好不过了,经测试80%左右都有提示,已经很好了. 其他js库同 ...
- Faces.JavaServer Pages(JSP)
zhengly.cn atitit.Servlet2.5 Servlet 3.0 新特性 jsp2.0 jsp2.1 jsp2.2新特性 1.1. Servlet和JSP规范版本对应关系:1 1.2. ...
- 代码世界中的Lambda
“ λ ”像一个双手插兜儿,独自行走的人,有“失意.无奈.孤独”的感觉.λ 读作Lambda,是物理上的波长符号,放射学的衰变常数,线性代数中的特征值……在程序和代码的世界里,它代表了函数表达式,系统 ...
- predis如何实现phpredis的pconnect方法
predis和phpredis都是redis的php客户端,区别可以看这里,这里不赘述. phpredis是php扩展,由C语言编写,诞生较早,很多PHPer都熟悉. predis是用PHP语言编写, ...
- Tomcat启动分析(Tomcat7.0)
1)bin目录下的bootstrap.jar中的main方法启动Tomcat org.apache.catalina.startup.Bootstrap类下的main方法 可以看到Bootstrap类 ...
- "Invalid bound statement (not found): com.sitech.admin.dao.TbOpenAbilityInfoDao.findAbilityReadyUp"mybatis配置文件bug
问题描述: 通常在正常启动某项工程后操作某个功能时抛出的bug: org.apache.ibatis.binding.BindingException: Invalid bound statement ...
- RAC oracle删除数据库
24:site2-DMS1:~ # su - oracleoracle@site2-DMS1:~> sqlplus / as sysdba SQL*Plus: Release 11.2.0.3. ...
- 【itext】7步制作兼容各种文档格式的Itext5页眉页脚 实现page x pf y
itext5页眉页脚工具类,实现page x of y 完美兼容各种格式大小文档A4/B5/B3,兼容各种文档格式自动计算页脚XY轴坐标 鉴于没人做的这么细致,自己就写了一个itext5页眉页脚工具类 ...