zoukankan      html  css  js  c++  java
  • jQuery Tools——不可错过的jQuery UI库(四)

    今天讲解jQuery Tools中另一工具组件——滚动效果(Scrollable)。滚动效果在网页设计中也是经常用到的,例如滚动新闻、幻灯片展示、相册……(发挥想象力吧,用到选项卡的内容切换中是不是会很酷)。

    开始前还是要啰嗦几句,jQueryTools关注的是提供灵活可控的功能,而非展现。虽然官方站点也给我们提供了漂亮的示例,但是那些展现与jQueryTools的核心功能无关。理解了jQueryTools的功能使用,展现效果及其扩展任由发挥。例如今天要讲的示例,可能并不好看,也不能直接用到Web设计中,示例仅仅要告诉你的是工具的使用方法,绝非准则。

    先看一个最简单的例子(你可以点击方块或按键盘左右键触发滚动):

    HTML 代码

    <!-- 为scrollable区域定义一个根节点 --> 
    <div class="scrollable">
    <!-- 为所有滚动项定义根节点 -->
    <div class="items">
    <div>0</div> <div>1</div> <div>2</div> <div>3</div> <div>4</div>
    <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div>
    <div>10</div> <div>11</div> <div>12</div> <div>13</div> <div>14</div>
    </div>
    </div>

    如上面定义的,必须要给滚动区域定义一个根节点(为它定义一个class或id,方便找到它),还需要在里面为所有滚动项包裹一个根节点(必须为其定义class=”items”)。最里面的滚动项,你就可以随便定义了,可以使div之类,也可以是图片、flash等等的任意元素。

    Javascript Code:

    Scrollable的css书写上还真有些地方需要注意,下面看一下:

    CSS Code:

    /* 
    滚动区域根元素样式
    当滚动发生时,根元素应当是静止的
    */

    div.scrollable {
     
    /* 必须有的基本设定,大小可以自己设定 */
    position:relative;
    overflow:hidden;
    width: 660px;
    height:90px;
    }
     
    /*
    所有滚动项的根节点,必须使用绝对定位(position:absolute)
    必须赋予一个足够大的宽度,放下里面的所有元素
    它本身不必设定高度,因为在滚动区域根元素中已经设定
    */

    div.scrollable div.items {
    /* this cannot be too large */
    width:20000em;
    position:absolute;
    }
     
    /*
    滚动区域中的滚动项,在上面的横向滚动例子中至少要设定为左浮动
    */

    div.scrollable div.items div {
    float:left;
    }
     
    /* 滚动元素点击(active)时的样式 */
    div.items div.active {
    border:1px inset #ccc;
    background-color:#fff;
    }

    纵向滚动与很想滚动的实现差不多,演示效果可以看这里。下面看一下滚动效果初始化的不同:

    <script> 
    $(function() {
    // 初始化滚动效果
    $("div.scrollable").scrollable({
    vertical:true, //设定为纵向滚动
    size: 3 //设定滚动显示的滚动项数目,这里注意与高度的设定配合
    });
    });
    </script>

    下面这个例子是为滚动效果加上导航,及鼠标滑轮控制滚动的效果:

    上面的例子中,可以通过鼠标点击滚动项、左右导航、上方翻页导航、鼠标滑轮滚动(鼠标放在滚动区域)、键盘左右键触发滚动效果。

    说明:

    1. 通过鼠标滑轮控制滚动的功能,要另外引用jquery的一款插件jquery.mousewheel
    2. 左右导航及翻页导航,是通过特定的html定义完成的,不是脚本参数,如下:
       
      <!--翻页导航,class定义为navi-->
      <div class="navi"></div>
       
      <!-- 下一项导航链接,class定义为“prev”或“prevPage” -->
      <a class="prev"></a>
       
      <div class="scrollable">
      <div class="items">
      <div>0</div> <div>1</div> <div>2</div> <div>3</div> <div>4</div>
      <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div>
      <div>10</div> <div>11</div> <div>12</div> <div>13</div> <div>14</div>
      </div>
       
      </div>
       
      <!-- 下一项导航链接,class定义为“next”或“nextPage” -->
      <a class="next"></a>
       
      <!--清除浮动-->
      <br clear="all" />

      需要注意的是上一项链接class必须声明为prev或prevPage,下一项链接必须声明为nextPage或next。并且,上一项与下一项元素必须与滚动区域根节点在dom树的同一级上,也就是有共同的父节点。(在上面的例子中,上一项与下一项功能失效就是因为wordpress自动为两个链接包裹了P元素,很无奈,不知道该怎么去掉)

    下面这个例子是通过配置参数,使之自动滚动。

    看一下初始化时的参数配置:

        // initialize scrollable  
    $("div.scrollable").scrollable({
     
    // 设定滚动间隔,单位毫秒
    interval: 2000,
     
    // 是否循环,遇到最后一项时,是否从新第一项
    loop: true,
     
    // 比正常模式添加一点动画效果
    speed: 600,
     
    // 滚动开始时,让滚动项有个适当的透明效果
    onBeforeSeek: function() {
    this.getItems().fadeTo(300, 0.2);
    },
     
    // 滚动结束时,取消透明效果
    onSeek: function() {
    this.getItems().fadeTo(300, 1);
    }
    });

    这里有一个使用scrollable效果做的比较好看的例子,感兴趣可以看下。

  • 相关阅读:
    phoneGap
    backbonejs使用
    优化后的光标插件
    选择文本,范围
    js最佳继承范型
    深入理解事件捕获冒泡
    keyCode,charCode,which
    与IE奋战的血泪史
    【程序员的自我修养】如何使用IRC
    【程序员的自我修养】写给新手程序员的一封信
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/1813650.html
Copyright © 2011-2022 走看看