Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 210|回复: 0

[默认分类] iScroll.js 用法参考 (share)

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-7-7 17:12:05 | 显示全部楼层 |阅读模式
    分享是传播、学习知识最好的方法
    以下这篇文章是iScroll.js官网的中文翻译,尽管自己英文不好,但觉得原作者们翻译的这个资料还是可以的,基本用法介绍清楚了。如果你英文比较好的话,可以看看官网的资料。
    参考:http://www.cnblogs.com/asqq/arcHive/2012/04/23/2466132.HTML  ,  http://www.nb88.net/Index/p/id/406
    官网:http://cubiq.org/iscroll-4

    概要

    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的结构如下所示:



    1. <div id="wrapper">
    2.         <ul>
    3.                <li></li>
    4.                .....
    5.         </ul>
    6. </div>
    复制代码


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


    1. <div id="wrapper">
    2.         <div id="scroller">
    3.                <ul>
    4.                     <li></li>
    5.                      ...
    6.                 </ul>
    7.                 <ul>
    8.                      <li></li>
    9.                      ...
    10.                 </ul>
    11.        </div>
    12. </div>
    复制代码

    在这个例子中,scroller这个元素可以滚动,即便它包含两个ul元素
    iScroll必须在调用之前实例化,你可以在下面几种情况下对iScroll进行实例化:

      (1)使用onDOMContentLoaded事件实现滚动
            适用于滚动内容只包含文字、图片,并且所有的图片都有固定的尺寸   

    1. <script src="iscroll.js"></script>
    2.         <script>
    3.                 var myscroll;
    4.                 function loaded(){
    5.                            myscroll=new iScroll("wrapper");
    6.                  }
    7.                window.addEventListener("DOMContentLoaded",loaded,false);
    8.          </script>
    复制代码

             注意:myscroll这个变量是全局的,因此你可以在任何地方调用它
        (2)使用onLoad事件实现滚动
            因为DOMContentLoaded事件是载入DOM结构后就会被调用,所以在图片等元素未载入前可能无法确定滚动区域的长宽,此时可以使用onLoad事件来实现。
            


    1. <script src="iscroll.js"><script>
    2.         <script>
    3.                     var myscroll;
    4.                     function loaded(){
    5.                    setTimeout(function(){
    6.                             myscroll=new iScroll("wrapper");
    7.                      },100 );
    8.                 }
    9.                 window.addEventListener("load",loaded,false);
    10.          </script>
    复制代码

              这种情况下iScroll会在页面资源(包括图片)加载完毕100ms之后得到初始化,这应该是一种比较安全的调用iScroll的方式。
        (3)inline初始化
              这种情况会在页面加载到js的时候就进行调用,此方法不推荐使用,但是很多javascript的大牛都在用这种方式,我又有什么理由不赞成呢?         

    1. <script src="iscroll.js"></script>
    2.                     <div id="wrapper">
    3.                             <ul>
    4.                                 <li></li>
    5.                                  ...
    6.                           </ul>
    7.                   </div>
    8.         <script>
    9.                    var myscroll=new iScroll("wrapper");
    10.         </script>
    复制代码

             不过建议你使用一些框架的ready方法来安全调用iScroll(比如jquery里的ready())。
      iScroll里传递的参数
      iScroll里的第二个参数允许你自定义一些内容,比如下面的这段代码:      

    1.      <script>
    2.           var myscroll=new iScroll("wrapper",{hScrollbar:false, vScrollbar:false});
    3.        </script>
    复制代码


      第二个参数通常都是一个对象,像上面的这个例子里就设定了不显示滚动条。常用的参数如下:
                   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里也是得到支持的。要使用缩放功能,你至少需要如下配置:               

    1. var myScroll =new iScroll("wrapper",{zoom:true});
    复制代码

            如果你想对缩放功能进行深度的自定义的话可以使用下面的一些选项:
                   zoomMax   指定允许放大的最大倍数,默认为4
          【注意事项】:如果想要图片缩放的效果很好的话要把他们放到硬件的合成层中。通俗点说,就是在所有需要缩放的img元素上使用-webkit-transform:translate3d(0,0,0)来实现,而且尤为重要的是,硬件的加速会占用大量资源,要谨慎使用,否则你的应用可能就此崩溃。
    捕捉元素(snap and snap to element)  "Carousel" demo
      SNAP功能是判断元素是否滑动到指定位置。通过这个效果可以制作花哨的跑马灯效果。
      插件会自动分析滚动区域内相同标签或相同大小的元素做为捕捉对象,也可以通过参数指定捕捉的对象               

    1. var myscroll=new iScroll("wrapper",{
    2.                        snap:true,
    3.                        momentum:false,
    4.                        hScrollbar:false,
    5.                        vScrollbar: false
    6.                   });
    复制代码

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

    1. var myscroll=new iScroll("wrapper",{
    2.                       snap:"li",
    3.                       momentum:false,
    4.                       hScrollbar:false,
    5.                       vScrollbar:false
    6.                 });
    复制代码

                在这个例子中scroller可以捕捉到滚动区域中最左上角的li元素
    自定义滚动条(custom scrollbars)
              在iScroll 4这个版本中,可以利用一系列的css来自定义滚动条的呈现。可以给滚动条添加一个class参数,如下:                  

    1. var myscroll=new iScroll("wrapper",{
    2.   scrollbarClass: "myScrollbar"});
    复制代码

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

    1.           <div class="myScrollbarV">
    2.                           <div></div>
    3.                   </div>
    4.                  .myscrollbarV{
    5.                            position:absolute;z-index:100;width:8px;bottom:7px;top:2px;right:1px;
    6.                   }
    7.                 .myScrollbarV > div {
    8.                            position:absolute;
    9.                            z-index:100;
    10.                            width:100%;
    11.                              /* The following is probably what you want to customize */
    12.                            background:-webkit-gradient(linear, 0 0, 100% 0, from(#f00), to(#900));
    13.                            border:1px solid #800;
    14.                           -webkit-background-clip:padding-box;
    15.                           -webkit-box-sizing:border-box;
    16.                           -webkit-border-radius:4px;
    17.                           -webkit-box-shadow:inset 1px 1px 0 rgba(255,255,255,0.5);
    18.                  }
    复制代码

      通用方法:
          (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改变后自动刷新

      
      
      
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-6-7 21:38 , Processed in 0.473637 second(s), 48 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表