JavaScript实现简单的图片切换

JavaScript实现图片切换,主要用到setInterval()函数和clearInterval()函数,前者功能是开启动画,后者功能则为清除动画(可理解为使动画停止),为了使动画停止,则需要定义全局变量作为标志,标志返回setInterval()函数的id,id作为clearInterval()函数的引用,目的是为了告诉clearInterval()函数动画暂停的位置。下面是实现的代码:

部分HTML代码:第一个 为左按钮,是一张带箭头的透明图片,点击实现图片右滑动,第二个为图片展示区域,第三个是右按钮,点击实现图片左滑动。

<body onload="change()">
    <div id="changePhotos">
            <img src="images/left.png" id="leftimg" onclick="rightMove()"/>
            <img id="photo" src="images/4.jpg" onmouseover="off()" onmouseout="on()" />
            <img src="images/right.png" id="rightimg" onclick="leftMove()"/>    
    </div>
 </body>

JavaScript全部代码:JS主要实现鼠标放在图片上方,动画暂停,移开图片动画开始,以及点击左右按钮,图片的左右切换。

var photos = ['images/1.jpg','images/2.jpg','images/3.jpg','images/4.jpg','images/5.jpg'];
var count = 0; //记录图片张数
var flag; //返回动画id
function callback() //实现图片切换
{   
    document.getElementById("photo").src = photos[count];
    count++;
    if (count == photos.length)
        count = 0;  
}   

function change() //动画开启
{
    flag = setInterval(callback,2000);  
}

function off() //onmouseover事件发生,动画暂停
{
    clearInterval(flag);
}

function on() //onmouseout事件发生,动画继续
{
    flag = setInterval(callback,2000);  
}

function leftMove() //实现左滑动
{
    document.getElementById("photo").src = photos[count];
    count++;
    if (count == photos.length)
        count = 0;
}

function rightMove() //实现右滑动
{
    count--;
    document.getElementById("photo").src = photos[count];
    if (count <= 0)
        count = photos.length - 1;
}

整体实现代码比较简单,具体展示样式则用到CSS,希望对初学者有所帮助!

-------------本文结束感谢您的阅读-------------