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>