一、所用到的知识点

1.DOM操作

2.定时器

3.事件运用

4.Js动画

5.函数递归

6.无限滚动大法

二、结构和样式

<div id="banner" class="banner">
    <ul id="list-banner" class="list-banner fn-clear" style="left:-624px;">  
            <li><a href="#"><img src="data:images/banner4.jpg" width="624" height="200" alt="" title="" /></a></li>
            <li><a href="#"><img src="data:images/banner1.jpg" width="624" height="200" alt="" title="" /></a></li>
            <li><a href="#"><img src="data:images/banner2.jpg" width="624" height="200" alt="" title="" /></a></li>
            <li><a href="#"><img src="data:images/banner3.jpg" width="624" height="200" alt="" title="" /></a></li>
            <li><a href="#"><img src="data:images/banner4.jpg" width="624" height="200" alt="" title="" /></a></li>
            <li><a href="#"><img src="data:images/banner1.jpg" width="624" height="200" alt="" title="" /></a></li>
    </ul>
    <div class="list-num-wp">
        <div id="list-num" class="list-num fn-clear">
            <a href="#" class="hover"></a>
            <a href="#"></a>
            <a href="#"></a>
            <a href="#"></a>
        </div>
    </div>
    <div class="left">
        <a id="left" href="#"></a>
    </div>
    <div class="right">
        <a id="right" href="#"></a>
    </div>
</div>

.banner{position:relative;width:624px;height:200px;overflow:hidden;}
.banner .list-banner{position:absolute;width:5000px;}
.banner .list-banner li{float:left;width:624px;height:200px;}
.banner .list-num-wp{position:absolute;bottom:7px;width:624px;height:11px;}
.banner .list-num{width:100px;margin:0 auto;}
.banner .list-num a{display:inline;float:left;width:11px;height:11px;margin:0 7px; background:url(../images/list-num.png) no-repeat;}
.banner .list-num a:hover{background:url(../images/list-num-hover.png));}
.banner .list-num a.hover{background:url(../images/list-num-hover.png);}
.banner .left a{display:block;position:absolute;width:49px;height:49px;top:75px;left:4px;background:url(../images/arrow.gif) 0 0;filter: Alpha(opacity=50);-moz-opacity:.5;opacity:0.5;}
.banner .right a{display:block;position:absolute;width:49px;height:49px;top:75px;right:4px;background:url(../images/arrow.gif) 0 -49px;filter: Alpha(opacity=50);-moz-opacity:.5;opacity:0.5;}

三、脚本思路

1.先左右按钮功能

window.onload=function(){
    var prev=document.getElementById("left");
    var next=document.getElementById("right");
    var list_banner=document.getElementById("list-banner");
    next.onclick=function(){
        list_banner.style.left=parseInt(list_banner.style.left)-624+'px';    //注:html上的ul要加行间样式left:0;,否则这里动不起来
    }
    prev.onclick=function(){
        list_banner.style.left=parseInt(list_banner.style.left)+624+'px';    
    }
}

2.左右按钮点击的两句话很像,封装成函数

function animate(offset){
        list_banner.style.left=parseInt(list_banner.style.left)+offset+'px';
    }
    next.onclick=function(){
        animate(-624);
    }
    prev.onclick=function(){
        animate(624);
    }

3.无限滚动

①假图的做法

即图片为412341,小于最后一张位置的时候,回到第一张的位置,大于  第一张位置的时候,拉到最后一张的位置

function animate(offset){
    var newLeft=parseInt(list_banner.style.left)+offset;
    list_banner.style.left=newLeft+'px';
    if(newLeft<-2496){
        list_banner.style.left=-624+"px";
    }
    if(newLeft>-624){
        list_banner.style.left=-2496+"px";
    }
}

4.小圆点跟着左右按钮切换

var index=1;
function showDot(){
    for(var i=0;i<list_num.length;i++){
        list_num[i].className="";
    }
    list_num[index-1].className="hover";
}
next.onclick=function(){
    animate(-624);
    index++;
    if(index>4){
        index=1;
    }
    showDot();
}
prev.onclick=function(){
    animate(624);
    index--;
    if(index<1){
        index=4;
    }
    showDot();
}

5.点击小圆点图片滚动及小圆点切换

for(var i=0;i<list_num.length;i++){
    list_num[i].onclick=function(){
        if(this.className=="hover"){
            return;
        }
        var myIndex=parseInt(this.getAttribute("index"));
        var offset=-624*(myIndex-index);
        index=myIndex;
        animate(offset);
        showDot();
    }
}

①点自己的时候不执行下列代码

②<div class="list-num-wp">
        <div id="list-num" class="list-num fn-clear">
            <a index="1" href="#" class="hover"></a>
            <a index="2" href="#"></a>
            <a index="3" href="#"></a>
            <a index="4" href="#"></a>
        </div>
    </div>

关键是要取到点击的是第几张图片,不能直接var myIndex=this.index;因为index是自定义属性,dom自带属性可以通过点来获取,自定义属性不行,.getAttribute()既可以获取自定义属性,又可以获取dom自带属性

③更新index值,index=myIndex;

6.动画函数(有一个渐变的运动过程)

function animate(offset){
        animated=true;
        var newLeft=parseInt(list_banner.style.left)+offset;
        var time=300;          //位移总时间
        var interval=30;       //位移间隔时间
        var speed=offset/(time/interval);       //每次移动距离
        speed=speed>0?Math.ceil(speed):Math.floor(speed);        //可能存在小数,取整
        function go(){
            if((speed < 0 && parseInt(list_banner.style.left)>newLeft)||(speed>0&&parseInt(list_banner.style.left)<newLeft)){      //newLeft目标值
                list_banner.style.left=parseInt(list_banner.style.left)+speed+'px';
                setTimeout(go,interval);   //不止做一次运动(go函数),每隔30毫秒前进一下
            }
            else{
                animated=false;
                list_banner.style.left=newLeft+'px';
                if(newLeft<-2496){
                    list_banner.style.left=-624+"px";
                }
                if(newLeft>-624){
                    list_banner.style.left=-2496+"px";
                }
            }
        }
        go();
    }
    next.onclick=function(){
        if(!animated){
            index++;
        }
        if(index>4){
            index=1;
        }
        showDot();
        if(!animated){
            animate(-624);
        }
    }
    prev.onclick=function(){
        if(!animated){
            index--;
        }
        if(index<1){
            index=4;
        }
        showDot();
        if(!animated){
            animate(624);
        }
    }
    
    for(var i=0;i<list_num.length;i++){
        list_num[i].onclick=function(){
            if(this.className=="hover"){
                return;
            }
            var myIndex=parseInt(this.getAttribute("index"));
            var offset=-624*(myIndex-index);
            index=myIndex;
            showDot();
            if(!animated){
                animate(offset);
            }
        }
    }

①一个函数不停地在一个条件后调用自身,这种做法就叫做递归,这里通过递归可以实现animate这个函数的动画效果

②不停点就意味着不停调用animate函数,可能会造成卡顿,图片乱刷,需要优化,引进变量animated

7.自动播放

function autoplay(){
        timer=setInterval(function(){
            next.onclick();
        },1000)
    }
    function stopautoplay(){
        clearInterval(timer);
    }

banner.onmouseover=stopautoplay;
    banner.onmouseout=autoplay;
    autoplay();

setTimeout只执行一次,之前一直执行,是因为递归

setInterval是每隔多少时间

8.假图的优化

实际运用中,图片肯定是按顺序存放,所以假图最好通过js来生成,而不是本身写在html上

var img_first=list_banner.getElementsByTagName("li")[0];
    var img_last=list_banner.getElementsByTagName("li")[3];
    list_banner.appendChild(img_first.cloneNode(true));
    list_banner.insertBefore(img_last.cloneNode(true),list_banner.getElementsByTagName("li")[0]);

appendChild是将新的节点添加到目标的最后一个子节点之后

insertBefore是将新的节点添加到已存在的子节点之前

cloneNode方法,true表示深克隆,false表示浅克隆,深克隆是将标签和标签里的内容都复制过来,而浅克隆不复制内容

[Js]焦点图轮播效果的更多相关文章

  1. JS、JQ实现焦点图轮播效果

    JS实现焦点图轮播效果 效果图: 代码如下,复制即可使用: (不过里面的图片路径需要自己改成自己的图片路径,否则是没有图片显示的哦) <!DOCTYPE html> <html> ...

  2. JS实现焦点图轮播效果

    大家平时逛淘宝网的时候,在首页就能看到焦点图轮播的效果,就是这个样子的: PS:想起每每打开淘宝,总会被这个玩意先夺眼球,偶尔还去点进去溜溜,幸好我定力好,总能控制住自己的购买欲望,为自己不用剁手感到 ...

  3. [Jquery]焦点图轮播效果

    $(function(){    var $next=$(".right");    var $prev=$(".left");    var $list_nu ...

  4. jQuery制作焦点图(轮播图)

    焦点图(轮播图) 案例 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...

  5. 原生JavaScript实现焦点图轮播

    不管是高校的网站还是电商的页面,焦点图的切换和轮播应该是一项不可或缺的应用.今天把焦点图轮播制作的技术要点做下笔记,以供日后查看. 一.结构层(HTML) 焦点图的HTML结构很简单,就是一个父容器( ...

  6. JavaScript基础 -- 焦点图轮播(转载)

    首先将HTML结构搭建好: <div id="container"> <div id="list" style="left: -60 ...

  7. 基于jQuery游戏网站焦点图轮播特效

    基于jQuery的一款游戏网站焦点图轮播特效.这是一款带进度条定时切换,带缩略图切换的jQuery网站焦点图代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <cente ...

  8. 用最简单的代码写出banner图轮播效果

    以下视频是由[赵一鸣随笔]博客提供的“用最简单的代码写出banner图轮播效果”. 查看全屏高清视频,请点击链接:http://www.zymseo.com/58.html

  9. html中使用JS实现图片轮播效果

    1.首先是效果图,要在网页中实现下图的轮播效果,有四张图片,每张图片有自己的标题,然后还有右下角的小方框,鼠标悬浮在小方框上,会切换到对应的图片中去. 2.先是HTML中的内容,最外层是轮播图整个的容 ...

随机推荐

  1. vi_命令

    1.文件末尾新增一行: 非编辑模式下,按大写的G 跳到最后一行. 然后按小写的O键,增加一行. 2.删掉一行: 非编辑状态下,光标定位到要删除的那一行,然后  dd 3.删字符 在非插入模式下,把光标 ...

  2. Linux_常用命令_01

    PS:一些不涉及其他软件的操作,OS本来就支持的命令. 1.压缩/解压: 压缩: tar -zcvf /home/android1.6_cmdCompress.tar.gz /root/manifes ...

  3. mysql 大数据量求平均值

    需求是:对于一个设备,求一天内每个小时的平均值,一个月内每天的平均值,更通用的需求是,从起始时间到结束时间,每隔一段时间,求一个平均值.目前的解决策略是:在存储过程中进行处理,从起始时间到结束时间,切 ...

  4. Android通过webservice对sqlserver数据库进行操作

    首页在AndroidManifest.xml中添加访问数据库权限 <uses-sdk android:minSdkVersion="7" /> <uses-per ...

  5. Python学习笔记13—错误和异常

    常见的异常:

  6. Delphi 程序结构

    注:该内容整理自以下链接. http://www.cnblogs.com/hackpig/archive/2010/02/15/1668513.html 概要介绍:Object Pascal语言的结构 ...

  7. Android App组件之ListFragment -- 说明和示例

    Android App组件之ListFragment -- 说明和示例 1 ListFragement介绍 ListFragment继承于Fragment.因此它具有Fragment的特性,能够作为a ...

  8. Android GestureDetector方法详解

    为了加强点击.拖动响应事件,Android提供了GestureDetector手势识别类.通过GestureDetector.OnGestureListener来获取当前被触发的操作手势(Single ...

  9. order by 容易出现的bug记录

    写分页查询时遇到一个问题: 在order by create_time 的时候,假设所有数据的create_time 值相同,那么 使用:select * from ( selelct s.*,row ...

  10. 转:Eric Lippert:阅读代码真的很难

    转自:http://blog.jobbole.com/438/ 相关文章 微软资深软件工程师:阅读代码真的很难(第2篇) 阅读优秀代码是提高开发人员修为的一种捷径 学会阅读源代码 如何阅读大型代码库? ...