jquery实现垂直无限轮播的方法分析

本文实例讲述了jquery实现垂直无限轮播的方法。分享给大家供大家参考,具体如下:

javascript垂直轮播,依赖于jquery实现的,并且首尾无缝衔接。原理很简单,就不讲述了,直接贴源码。

1.HTML节点

<div class=\"banner_group\">
    <ul id=\"banner\">
      <!-- 缓存末项,实现滑动到最开始后,无限轮播 -->
      <li style=\"background-color: chartreuse\">第四页</li>
      <li style=\"background-color: #f6894d\">第一页</li>
      <li style=\"background-color: royalblue\">第二页</li>
      <li style=\"background-color: red\">第三页</li>
      <li style=\"background-color: chartreuse\">第四页</li>
      <!-- 缓存首项,实现滑动到最后过后,无限轮播 -->
      <li style=\"background-color: #f6894d\">第一页</li>
    </ul>
    <div class=\"scrollPageBtn\">
      <div style=\"width: 100%;height: 100%;position: relative;\">
        <label id=\"last\" style=\"width:100%;position: absolute;top: 0;text-align: center\">↑</label>
        <label id=\"next\" style=\"width:100%;position: absolute;bottom: 0;text-align: center\">↓</label>
      </div>
    </div>
</div>

2.CSS样式

<style>
    body{
      margin:0;
      padding: 0;
    }
    .banner_group{
      width: 300px;
      height: 500px;
      overflow: hidden;
      position: relative;
    }
    .scrollPageBtn{
      width: 30px;
      height: 100%;
      position: absolute;
      top: 0;
      left: 40%;
      background-color: #b2b2b2;
      opacity: 0.2;
    }
    ul{
      list-style: none;
      width: 100%;
      height: 100%;
      margin: 0;
      padding: 0;
      position: relative;
    }
    ul li{
      width: 100%;
      height: 100%;
      color: white;
      font-size: 25px;
    }
</style>

3.JQuery准备

<!-- 引入jquery -->
<script src=\"http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js\"></script>

4.JavaScript代码

<script>
    var index = 0; // 保存当前所在项
    /* 是否允许点击滑动动画,如果正在执行动画的过程中,
    则禁止点击,如果动画完成后,则允许点击,
    避免由于连点,出现画面不正常问题. */
    var allowClick = true; //
    // 页面加载完成后调用
    $(function(){
      index = 1; // 初始显示第2项
  /* 注意:第一项是用来缓存末项的,实现无缝连接准备的,所以最开始显示的应该是第2项 */
      $(\"#banner\").css(\"bottom\", \"500px\"); // 准备初始显示项
  // 上一页
      $(\"#last\").on(\"click\", function(){
        if(allowClick){
          allowClick = false;
          index--; // 上一页,--
   // 如果已经到了最开始过后,动画完成后,定位到末项
          if(index == 0){
            $(\"#banner\").animate({bottom: (index * 500) + \'px\'}, \"fast\", \"swing\", function () {
              index = 4;
              $(\"#banner\").css(\"bottom\", \"2000px\"); // 定位到末项
              allowClick = true;
            });
          }else{
            $(\"#banner\").animate({bottom: (index * 500) + \'px\'}, \"fast\", \"swing\", function () {
              allowClick = true;
            });
          }
        }
      });
  // 下一页
      $(\"#next\").on(\"click\", function(){
        if(allowClick){
          allowClick = false;
          if(index <= 5){
            index ++; // 下一页++
            if(index == 5){
              $(\"#banner\").animate({bottom: (index * 500) + \'px\'}, \"fast\", \"swing\", function () {
                index = 1;
                $(\"#banner\").css(\"bottom\", \"500px\");
                allowClick = true;
              });
            }else{
              $(\"#banner\").animate({bottom: (index * 500) + \'px\'}, \"fast\", \"swing\", function () {
                allowClick = true;
              });
            }
          }
        }
      });
    });
</script>

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery图片操作技巧大全》、《jQuery表格(table)操作技巧汇总》、《jQuery切换特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery常见经典特效汇总》及《jquery选择器用法总结

希望本文所述对大家jQuery程序设计有所帮助。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容