微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

iScroll.js 使用方法参考

概要

iScroll 4 这个版本完全重写了iScroll这个框架的原始代码。这个项目的产生完全是因为移动版webkit浏览器(诸如iPhone,iPad,Android 这些系统上广泛使用) 提供了一种本地化的方式来对一个限定了高度和宽度的元素的内容进行滑动。很不幸的是,这种情况下所有的web应用的页面就不能够包含具有position:absolute的头、页尾或者是一个内容可滚动的 中间区域。

然而,Android系统最新修订版已经可以支持这种功能了(尽管支持的力度还不是特别好),Apple公司似乎不太情愿将one-finger滑动事件运用到div元素上。 除了以前版本的iScroll的特性以外,iScroll 4还包括如下的特性:

(1)缩放(Pinch/Zoom) (2)拉动刷新(Pull up/down to refresh) (3)速度和性能提升 (4)精确捕捉元素 (5)自定义滚动条 友情提示:iScroll 4并不是iScroll 3的简易替代版本,api文档已经不一样了。同时考虑到此版本正处于测试期,一些API可能会有细微的变化。

使用指南

在此文档中你会发现很多例子来教会你如何快速上手iScroll脚本库。参看文中的demo小例子并仔细阅读此文档,可能有点小无聊,但是这篇文章中却是iScroll这个脚本库的精髓之所在哦。 iScroll需要对所要进行滚动的元素进行初始化,并且不限定一个页面中使用iScroll的元素的个数(这里不考虑您的硬件配置)。滚动元素中内容的类型和长度在一定程度上将会影响iScroll脚本库里 可以同时使用的元素的个数。 使用iScroll这个脚本库时,DOM树的结构要足够简单,移除不必要的标签,尽量避免过多的标签嵌套使用。 最优的使用iScroll的结构如下所示:

rush:xhtml;">
  • .....

    在这个小例子中,ul标签将会被滚动。iScroll一定要与滚动内容外面的wrapper进行联系才会产生效果。 【注意事项】: 只有wrapper里的第一个子元素才可以滚动,如果你想要更多的元素可以滚动,那么你可以试试下面的这种写法:

    rush:xhtml;">
  • ...
    • ...

    在这个例子中,scroller这个元素可以滚动,即便它包含两个ul元素

    iScroll必须在调用之前实例化,你可以在下面几种情况下对iScroll进行实例化:

      

    (1)使用onDOMContentLoaded事件实现滚动

    适用于滚动内容只包含文字图片,并且所有的图片都有固定的尺寸

    rush:js;">

    注意:myscroll这个变量是全局的,因此你可以在任何地方调用

      (2)使用onLoad事件实现滚动

    因为DOMContentLoaded事件是载入DOM结构后就会被调用,所以在图片等元素未载入前可能无法确定滚动区域的长宽,此时可以使用onLoad事件来实现。

    rush:js;">

    这种情况下iScroll会在页面资源(包括图片)加载完毕100ms之后得到初始化,这应该是一种比较安全的调用iScroll的方式。

      (3)inline初始化

    这种情况会在页面加载到js的时候就进行调用,此方法不推荐使用,但是很多javascript的大牛都在用这种方式,我又有什么理由不赞成呢?

    rush:xhtml;">

    不过建议你使用一些框架的ready方法来安全调用iScroll(比如jquery里的ready())。

    iScroll里传递的参数

      iScroll里的第二个参数允许你自定义一些内容,比如下面的这段代码

    rush:js;">

    第二个参数通常都是一个对象,像上面的这个例子里就设定了不显示滚动条。常用的参数如下:

    hScroll false 禁止横向滚动 true横向滚动 认为true vScroll false 精致垂直滚动 true垂直滚动 认为true hScrollbar false隐藏水平方向上的滚动条 vScrollbar false 隐藏垂直方向上的滚动条 fixedScrollbar 在iOS系统上,当元素拖动超出了scroller的边界时,滚动条会收缩,设置为true可以禁止滚动条超出 scroller的可见区域。认在Android上为true, iOS上为false fadeScrollbar   false 指定在无渐隐效果时隐藏滚动条 hideScrollbar   在没有用户交互时隐藏滚动条 认为true bounce  启用或禁用边界的反弹,认为true momentum   启用或禁用惯性,认为true,此参数在你想要保存资源的时候非常有用 lockDirection false取消拖动方向的锁定, true拖动只能在一个方向上(up/down 或者left/right)

    各种效果的实现

    滚动刷新  'Pull to refresh' demo

    自从Twitter和一些Apple的本地化应用出现了这个效果之后,这个效果就变得非常流行。你可以看看这儿先一睹为快。 最新版中,作者把把"pull to refresh"这个部分单分出来作为iScroll的一个额外插件。你可以点击这儿看看pull to refresh是如何工作滴。你只需要做的就是自定义pullDownAction()这个方法。你可能需要一个ajax来加载新的内容,不过一旦DOM树发生了变化要记得调用refresh这个方法来。需要记住的是在例子中我们加了1秒的延迟来模拟网络的延迟效果。当然,如果你不想使用这个延迟,那就把setTimeout方法去掉就行了。

    缩放(pinch / zoom)  'Pull to refresh' demo

    我们不得不面对一个事实,那就是光有滚动其实没什么新意的。这就是为什么在iScroll 4这个版本里我们允许你可以放 大和缩小。想要这个功能,只需要设置放大的参数zoom 为true即可实现利用手势来放大和缩小。你可以看看这儿。 双击放大和缩小的功能在iScroll 4里也是得到支持的。要使用缩放功能,你至少需要如下配置:

    var myScroll =new iScroll("wrapper",{zoom:true}); 如果你想对缩放功能进行深度的自定义的话可以使用下面的一些选项: zoomMax 指定允许放大的最大倍数,认为4 【注意事项】:如果想要图片缩放的效果很好的话要把他们放到硬件的合成层中。通俗点说,就是在所有需要缩放的img元素上使用-webkit-transform:translate3d(0,0)来实现,而且尤为重要的是,硬件的加速会占用大量资源,要谨慎使用,否则你的应用可能就此崩溃。

    捕捉元素(snap and snap to element)  'Carousel' demo

      SNAP功能判断元素是否滑动到指定位置。通过这个效果可以制作花哨的跑马灯效果

      插件自动分析滚动区域内相同标签或相同大小的元素做为捕捉对象,也可以通过参数指定捕捉的对象

    rush:js;"> var myscroll=new iScroll("wrapper",{ snap:true,momentum:false,hScrollbar:false,vScrollbar: false });

    可以通过设置snap参数为指定标签来设定捕捉对象。比如捕捉li标签

    rush:js;"> var myscroll=new iScroll("wrapper",{ snap:"li",vScrollbar:false });

    在这个例子中scroller可以捕捉到滚动区域中最左上角的li元素

    自定义滚动条(custom scrollbars)

    在iScroll 4这个版本中,可以利用一系列的css来自定义滚动条的呈现。可以给滚动条添加一个class参数,如下:

    rush:js;"> var myscroll=new iScroll("wrapper",{   scrollbarClass: "myScrollbar" });

    需要提醒的是,滚动条是由两个元素组合而成的:容器和显示器。容器同wrapper的高度相同,而显示器则代表的是滚动条本身。 滚动条的HTML结构如下:

    rush:xhtml;">
    .myscrollbarV{ position:absolute;z-index:100;width:8px;bottom:7px;top:2px;right:1px; } .myScrollbarV > div { position:absolute; z-index:100; width:100%; /* The following is probably what you want to customize */ background:-webkit-gradient(linear,0 0,100% 0,from(#f00),to(#900)); border:1px solid #800; -webkit-background-clip:padding-Box; -webkit-Box-sizing:border-Box; -webkit-border-radius:4px; -webkit-Box-shadow:inset 1px 1px 0 rgba(255,255,0.5); }

    通用方法

    (1)refresh 在DOM树发生变化时,应该调用方法 eg: setTimeout(function () { myScroll.refresh(); },0);

    (2)iScroll还提供了scrollTo,scrolltoElement和scrollToPage三个方法让你能够通过javascript来控制滚动效果。     scrollTo(x,y,time,relative):在指定的time时间内让内容滚动条x/y的位置。如myScroll.scrollTo(0,-100,200) 在200毫秒内Y轴向下滚动100像素。 myScroll.scrollTo(0,10,200,true)可以实现相对当前位置在200毫秒内Y轴向上滚动10像素的效果。     scrolltoElement(element,time):在指定的时间内滚动到指定的元素。如myScroll.scrolltoElement('li:nth-child(10)',100) 在100毫秒内滚动到第10个li元素的位置。第1个参数可以用CSS3中的选择器来筛选元素。     snapToPage(pageX,pageY,time):在200毫秒内从第1页滚动到第2页(0代表第1页,1代表第2页)。这个使用SNAP功能的时候可以调用这个函数

    (3)detroy() 完全消除myscroll及其占用的内存空间 eg: myscroll.destroy();  myScroll = null;

    iScroll的发展方向

    表单域的支持 缩放的优化 更好的桌面浏览器的兼容性 onScrol事件的优化 加个哈希值的变化 DOM改变后自动刷新

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

    相关推荐


    什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
    前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
    最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
    js如何实现弹出form提交表单?(图文+视频)
    js怎么获取复选框选中的值
    js如何实现倒计时跳转页面
    如何用js控制图片放大缩小
    JS怎么获取当前时间戳
    JS如何判断对象是否为数组
    JS怎么获取图片当前宽高