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,希望对初学者有所帮助!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。