注:代码来自17sucai网,已去除部分冗余代码,只保留图片效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml">

<head>

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  <title>jquery图片滚动</title>

  <meta name="description" content="jquery图片特效焦点图片轮播切换效果,带索引按钮控制和左右按钮控制图片切换。" />

  <style type="text/css">

    *{margin:0;padding:0;}

    .wrapper{width:800px;margin:0 auto;padding-bottom:50px;}

     /* focus */

     #focus{width:800px;height:280px;overflow:hidden;position:relative;}

     #focus ul{height:380px;position:absolute;}

     #focus ul li{float:left;width:800px;height:280px;overflow:hidden;position:relative;background:#000;}

     #focus ul li div{position:absolute;overflow:hidden;}

     #focus .btnBg{position:absolute;width:800px;height:20px;left:0;bottom:0;background:#000;}

     #focus .btn{position:absolute;width:780px;height:10px;padding:5px 10px;right:0;bottom:0;text-align:right;}

     #focus .btn span{display:inline-block;_display:inline;_zoom:1;width:25px;height:10px;_font-size:0;margin-left:5px;cursor:pointer;background:#fff;}

     #focus .btn span.on{background:#fff;}

     #focus .preNext{width:45px;height:100px;position:absolute;top:90px;background:url(img/sprite.png) no-repeat 0 0;cursor:pointer;}

     #focus .pre{left:0;}

     #focus .next{right:0;background-position:right top;}

  </style>

  <script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>

  <script type="text/javascript">

    $(function() {  

      var sWidth = $("#focus").width(); //获取焦点图的宽度(显示面积)

      var len = $("#focus ul li").length; //获取焦点图个数  

      var index = 0;  var picTimer;    //以下代码添加数字按钮和按钮后的半透明条,还有上一页、下一页两个按钮  

      var btn = "<div class='btnBg'></div><div class='btn'>";  

      for(var i=0; i < len; i++) {   

        btn += "<span></span>";  

      }  

      btn += "</div><div class='preNext pre'></div><div class='preNext next'></div>";  

      $("#focus").append(btn);  

      $("#focus .btnBg").css("opacity",0.5);

       //为小按钮添加鼠标滑入事件,以显示相应的内容

      $("#focus .btn span").css("opacity",0.4).mouseover(function() {   

        index = $("#focus .btn span").index(this);   

        showPics(index);  

      }).eq(0).trigger("mouseover");

      //上一页、下一页按钮透明度处理  

      $("#focus .preNext").css("opacity",0.2).hover(function() {   

        $(this).stop(true,false).animate({"opacity":"0.5"},300);  

      },function() {   

        $(this).stop(true,false).animate({"opacity":"0.2"},300);  

      });

       //上一页按钮  

      $("#focus .pre").click(function() {   

        index -= 1;   

        if(index == -1) {

          index = len - 1;

        }   

        showPics(index);  

      });

       //下一页按钮  

      $("#focus .next").click(function() {   

        index += 1;   

        if(index == len) {

          index = 0;

        }   

        showPics(index);  

      });

       //本例为左右滚动,即所有li元素都是在同一排向左浮动,所以这里需要计算出外围ul元素的宽度  

      $("#focus ul").css("width",sWidth * (len));    

      //鼠标滑上焦点图时停止自动播放,滑出时开始自动播放  

      $("#focus").hover(function() {   

        clearInterval(picTimer);  

      },function() {   

        picTimer = setInterval(function() {    

          showPics(index);    

          index++;    

          if(index == len) {

            index = 0;

          }   

        },4000); //此4000代表自动播放的间隔,单位:毫秒  

      }).trigger("mouseleave");    

      //显示图片函数,根据接收的index值显示相应的内容  

      function showPics(index) {

        //普通切换   

        var nowLeft = -index*sWidth;

        //根据index值计算ul元素的left值   

        $("#focus ul").stop(true,false).animate({"left":nowLeft},300);

        //通过animate()调整ul元素滚动到计算出的position   

        //$("#focus .btn span").removeClass("on").eq(index).addClass("on");

        //为当前的按钮切换到选中的效果   

        $("#focus .btn span").stop(true,false).animate({"opacity":"0.4"},300).eq(index).stop(true,false).animate({"opacity":"1"},300);

        //为当前的按钮切换到选中的效果  

      }

    });

  </script>

</head>

<body>

  <div class="wrapper"> 

    <div id="focus">    

      <ul>     

        <li><img src="img/01.jpg"  /></li>     

        <li><img src="img/02.jpg"  /></li>     

        <li><img src="img/03.jpg"  /></li>     

        <li><img src="img/04.jpg"  /></li>     

        <li><img src="img/05.jpg"  /></li>    

      </ul>   

    </div>    

  </div>

</body>

</html>

jquery图片滚动的更多相关文章

  1. 【精心推荐】12款很好用的 jQuery 图片滚动插件

    这里收集了12款很好用的 jQuery 图片滚动插件分享给大家.jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各 ...

  2. 10款很好用的 jQuery 图片滚动插件

    jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各种很酷的图片效果,它可以让的网站更具吸引力.这里收集了10款很好 ...

  3. jquery图片滚动仿QQ商城带左右按钮控制焦点图片切换滚动

    jquery图片滚动仿QQ商城带左右按钮控制焦点图片切换滚动 http://www.17sucai.com/pins/demoshow/382

  4. 求帮忙解决封装jquery图片滚动问题

    今天用jquery封装了点击图片滚动,但是发现在屏幕自适应时,图片停在的位置会随着屏幕大小而错位(我引入了pocketgrid.css响应式文件,但没办法去那边修改onsize事件...),求大神.. ...

  5. jQuery图片滚动插件

    //该组件目前仅适用于一次移动一张图片的情况 (function ($) { $.fn.extend({ "scroll": function (options) { option ...

  6. jquery图片滚动jquery.scrlooAnimation.js

    ;(function ($, window, document, undefined) { var pluginName = "scrollAnimations", /** * T ...

  7. jquery 图片滚动

    效果图: $(function(){    $("#roll-img2").html($("#roll-img").html());    function r ...

  8. jquery图片滚动normalizy.css

    article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block; ...

  9. jquery图片滚动demo.css

    body, html { font-size: 100%; padding: 0; margin: 0;} /* Reset */*,*:after,*:before { -webkit-box-si ...

随机推荐

  1. iOS开发UI篇——简单的浏览器查看程序

    一.程序实现要求 1.要求 2. 界面分析 (1) 需要读取或修改属性的控件需要设置属性 序号标签 图片 图片描述 左边按钮 右边按钮 (2) 需要监听响应事件的对象,需要添加监听方法 左边按钮 右边 ...

  2. Swift - 31 - 常量参数, 变量参数和inout参数

    //: Playground - noun: a place where people can play import UIKit // swift中默认情况下, 传入的参数是不可以修改的, 也就是l ...

  3. Asp.net 主题 【2】

    通常我们经常看到网页,一些软件提供换肤功能,各种主题间切换.ASP.NET 2.0 中可以用Theme和skin以及CSS轻松实现这个功能. 首先简单介绍一下三种技术:主题(Theme)技术,面板(s ...

  4. BOM和DOM详解

    DOM介绍 D(文档)可以理解为整个Web加载的网页文档,O(对象)可以理解为类似window对象只来的东西,可以调用属性和方法,这里我们说的是document对象,M(模型)可以理解为网页文档的树形 ...

  5. [转]memmove函数

    [FROM MSDN && 百科] 原型:  void *memmove( void* dest, const void* src, size_tcount ); #include&l ...

  6. rhel安装eclipse

    smb --> IDE --> 环境gcc(开发c) g++(开发c++)c++操作linux --> sqlite数据库linux平台自带sqlite数据库 基本SQL语言划分:D ...

  7. Java学习----方法的重载

    一个类中有多个同名的参数不一样的方法. 作用:可以根据不同的条件调用不同的方法. 注意:java不会因为方法的返回类型或者权限的不同而判断为不同的两个方法. public class Student ...

  8. 基于jq插件开发及弹窗实例

    基于jq的插件开发是什么鬼,$.fn是什么鬼,我在实际工作中也遇到过这个问题,下面就让我们一起来看一看这些都是什么鬼. 首先我们介绍$.fn. $.fn是指jquery的命名空间,加上fn上的方法及属 ...

  9. 初涉JavaScript模式 (2) : 基本技巧

    尽量少用全局变量 大量使用全局变量会导致的后果 全局变量创建以后会在整个JavaScript应用和Web页面中共享.所有的全局变量都存在于一个全局命名空间内,很容易发生冲突 不知不觉创建了全局变量 其 ...

  10. 如何用angularjs制作一个完整的表格之四__自定义ng-model标签的属性使其支持input之外的html元素

    有的时候我们需要为非input类型的元素添加ng-model来实现双向的数据绑定,从而减少冗余代码,那么可以尝试一下的方式 例如:我页面中使用了contenteditable这个属性来实现用户可直接编 ...