标签:
1
2
3
4
5
6
7
8
9
|
<div id= "wrapper" > //overflow:hidden; <ul> //只有第一个DOM结构(ul)被实例化,这个DOM可以纵向或者横向的滚动, //多出的内容会被wrapper的样式hidden。 <li>1</li> <li>2</li> <li>3</li> </ul> </div> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<div id= "wrapper" > //overflow:hidden; <div id= "first" > //只有第一个DOM结构(ul)被实例化,这个DOM可以纵向或者横向的滚动, //多出的内容会被wrapper的样式hidden <ul> <li>1</li> <li>2</li> <li>3</li> </ul> <ul> <li>4</li> <li>5</li> <li>6</li> </ul> </div> </div> |
1
|
var myScroll = new iScroll( "wrapper" ); |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
HTML: //HTML结构 <html > <body> ...code... </body> //插入iscroll.js文件 <script type= "text/javascript" src= "js/iscroll.js" > </script > //插入本页面JS文件 <script type= "text/javascript" src= "js/uw3c.js" > </script > </html> JS: //JS文件内容 var myscroll; function iscroll(data){ //实例化iScroll myscroll= new iScroll( "wrapper" ); pageData(data); } function pageData(obj){ $( "body" ).html(obj); myscroll.refresh(); //当DOM结构发生变化的时候,需要刷新iScroll } iscroll( "<div>pagedata</div>" ); |
1
|
var myscroll= new iScroll( "wrapper" ,{hScrollbar: false }); |
1
2
3
4
5
6
|
var opts = { vScroll: false , //禁止垂直滚动 snap: true , //执行传送带效果 hScrollbar: false //隐藏水平方向上的滚动条 }; var myscroll = new iScroll( "wrapper" ,opts); |
1
2
3
4
5
6
7
8
9
10
11
|
hScroll false 禁止横向滚动 true 横向滚动 默认为 true vScroll false 禁止垂直滚动 true 垂直滚动 默认为 true hScrollbar false 隐藏水平方向上的滚动条 vScrollbar false 隐藏垂直方向上的滚动条 fadeScrollbar false 指定在无渐隐效果时隐藏滚动条 hideScrollbar 在没有用户交互时隐藏滚动条 默认为 true bounce 启用或禁用边界的反弹,默认为 true momentum 启用或禁用惯性,默认为 true , 此参数在你想要保存资源的时候非常有用 lockDirection false 取消拖动方向的锁定, true 拖动只能在一个方向上(up/down 或者left/right) |
1
2
3
4
|
//在200毫秒的时间内,Y轴向上滚动100像素; uw3c.scrollTo(0, -100, 200) //在200毫秒的时间内,相对于当前位置,X轴向左滚动100像素; uw3c.scrollTo(-100, 0, 200, true ) |
1
|
uw3c.refresh(); //刷新iScroll |
1
2
3
4
5
6
7
8
|
onPosChange: function (x,y){ if (y < -200){ //如果Y周向上滚动200像素,$("#uw3c")就显示,否则就隐藏。 $( "#uw3c" ).show(); } else { $( "#uw3c" ).hide(); } } |
1
2
3
4
|
//滚动结束后,执行的方法,滚动后会出现提示框alert("uw3c.com") onScrollEnd: function (){ alert( "uw3c.com" ); } |
截至到笔者发布这篇文章时,通过样式:
IOS5 已经能够支持区域滚动了。但是andriod4 还是不行...
iScroll 使用起来很简单,首先你需要一个合理的DOM结构:
其次是推荐的样式:
官方推荐这样的结构,因为iscroll只能滚动wrapper里的第一个子节点,或者说唯一一个子节点才能使得iscroll正确的生效。因为这个节点需要一个绝对定位的CSS属性,更重要的是这个节点里所包裹的内容有了一个统一的容器,我们只需要计算之后修改这个容器的属性值就可以达到我们滚动的效果。
iscroll 需要两个参数,第一个很简单就是外容器的id,第二个参数是一个参数对象。
通过这个对象可以传入iscroll的各项参数来配置iscroll。
他的参数基本分为四个部分
以下由笔者整理的iScroll参数以及其代表的意思:
checkDOMChanges 这个不是十分靠得住,因为他目前是轮询检测offsetWidth、offsetHeight,然后才去调自身的refresh 重新计算滚动区域,但是有时候只检测这个不是很准..
通过scrollbar这些参数可以配置iscroll的滚动条,通过scrollbarClass可以自己定义一套滚动条的样式。
这个Zoom我觉得比较好用,对于一个固定显示图片区域的类似应用,可以非常简单的做到固定滚动,包括两指放大的应用。
wheelAction 这个参数是给PC的鼠标滚动定义的,可以定义为滚动鼠标滚轮放大。
通过了解以上参数,你可以非常容易的配置自己的iscroll 应用:
你可以通过onScrollEnd 事件回调在结束滚动后执行一段你自己的代码
你也可以简单的新建一个可以通过双触放大的固定滚动区域。
你也可以什么都不做,只是简单的约定碰到边界是否反弹,等等。
当然,在使用时,如果对创建的iscroll 实例保存引用会有很多好处:
你可以在内容改变时,DOM结构发生改变时调用 myscroll.refresh() 来重新计算固定滚动区域的内容高度,从而使得你的iscroll工作正常。
你也可以在你的应用结束时,用过这个引用调用destroy方法来,销毁这个iscroll 实例
等等....
当然,iscroll提供的Api也是非常丰富,所以我们可以通过使用iscroll来做很多webapp的应用,下一篇文章我将会主要介绍一下iscroll的公用调用方法,以及参数的控制。
标签:
原文地址:http://www.cnblogs.com/liubei/p/4786919.html