美文网首页代码改变世界
JavaScript实现简单的图片切换

JavaScript实现简单的图片切换

作者: 简心豆 | 来源:发表于2016-10-16 20:09 被阅读782次

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/1.jpg" onmouseover="off()" onmouseout="on()" />
            <img src="images/right.png" id="rightimg" onclick="leftMove()"/>   
    </div>
 </body>
二、JavaScript全部代码:JS主要实现鼠标放在图片上方,动画暂停,移开图片动画开始,以及点击左右按钮,图片的左右切换。
<script type="text/javascript">
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() //实现左滑动
{
    off(); //每次点击都让自动切换暂停
    document.getElementById("photo").src = photos[count];
    count++;
    if (count == photos.length)
        count = 0;
}

function rightMove() //实现右滑动
{
    off(); //每次点击都让自动切换暂停
    count--;
    document.getElementById("photo").src = photos[count];
    if (count <= 0)
        count = photos.length - 1;
}

</script>

相关文章

网友评论

    本文标题: JavaScript实现简单的图片切换

    本文链接:https://www.haomeiwen.com/subject/zrjeyttx.html