需求:无缝滚动。
思路:赋值第一张图片放到ul的最后,然后当图片切换到第五张的时候, 直接切换第六章,再次从第一张切换到第二张的时候先瞬间切换到, 第一张图片,然后滑动到第二张
步骤:
1.获取事件源及相关元素。(老三步)
2.复制第一张图片所在的li,添加到ul的最后面。
3.给ol中添加li,ul中的个数-1个,并点亮第一个按钮。
4.鼠标放到ol的li上切换图片
5.添加定时器
6.左右切换图片(鼠标放上去隐藏,移开显示)
在这里插入图片描述
代码如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style type="text/css">
*{ padding:0; margin:0; list-style:none; border:0;}
.all{
width:500px;
height:200px;
padding:7px;
border:1px solid #ccc;
margin:100px auto;
position:relative;
}
.screen{
width:500px;
height:200px;
overflow:hidden;
position:relative;
}
.screen li{ width:500px; height:200px; overflow:hidden; float:left;}
.screen ul{ position:absolute; left:0; top:0px; width:3000px;}
.all ol{ position:absolute; right:10px; bottom:10px; line-height:20px; text-align:center;}
.all ol li{ float:left; width:20px; height:20px; background:#fff; border:1px solid #ccc; margin-left:10px; cursor:pointer;}
.all ol li.current{ background:yellow;}
#arr {display: none;}
#arr span{ width:40px; height:40px; position:absolute; left:5px; top:50%; margin-top:-20px; background:#000; cursor:pointer; line-height:40px; text-align:center; font-weight:bold; font-family:'黑体'; font-size:30px; color:#fff; opacity:0.3; border:1px solid #fff;}
#arr #right{right:5px; left:auto;}
</style>
<script>
window.function () {
//需求:无缝滚动。
//思路:赋值第一张图片放到ul的最后,然后当图片切换到第五张的时候
// 直接切换第六章,再次从第一张切换到第二张的时候先瞬间切换到
// 第一张图片,然后滑动到第二张
//步骤:
//1.获取事件源及相关元素。(老三步)
var all = document.getElementById("all");
var screen = all.firstElementChild || all.firstChild;
var imgWidth = screen.offsetWidth;
var ul = screen.firstElementChild || screen.firstChild;
var ol = screen.children[1];
var div = screen.lastElementChild || screen.lastChild;
var spanArr = div.children;
//2.复制第一张图片所在的li,添加到ul的最后面。
var ulNewLi = ul.children[0].cloneNode(true);
ul.appendChild(ulNewLi);
//3.给ol中添加li,ul中的个数-1个,并点亮第一个按钮。
for(var i=0;i<ul.children.length-1;i++){
var olNewLi=document.createElement("li");
olNewLi.innerHTML=i+1;
ol.appendChild(olNewLi);
}
var olLiArr=ol.children;
olLiArr.className="current";
//4.鼠标放到ol的li上切换图片
for(var i=0;i<olLiArr.length;i++){
olLiArr[i].index=i;
olLiArr[i].function () {
for(var j=0;j<olLiArr.length;j++){
olLiArr[j].className="";
}
this.className="current";
//鼠标放到小的方块上的时候索引值和key以及square同步
key=square=this.index;
animate(ul,-this.index*imgWidth);
}
}
//5.添加定时器
var timer=setInterval(autoPlay,3000);
var key=0;
var square=0;
function autoPlay() {
key++;
if(key>olLiArr.length){
ul.style.left=0;
key=1;
}
animate(ul,-key*imgWidth);
square++;
if(square>olLiArr.length-1){
square=0;
}
for(var i=0;i<olLiArr.length;i++){
olLiArr[i].className="";
}
olLiArr[square].className="current";
}
//鼠标放上去清除定时器,移开后在开启定时器
all.function () {
div.style.display="block";
clearInterval(timer);
}
all.function () {
div.style.display="none";
timer=setInterval(autoPlay,3000);
}
//6.左右切换图片(鼠标放上去隐藏,移开显示)
spanArr[0].function () {
key--;
if(key<0){
ul.style.left = -imgWidth*(olLiArr.length)+"px";
key = olLiArr.length-1;
}
animate(ul,-key*imgWidth);
square--;
if(square<0){
square = olLiArr.length-1;
}
for(var i=0;i<olLiArr.length;i++){
olLiArr[i].className = "";
}
olLiArr[square].className = "current";
}
spanArr[1].function () {
autoPlay();
}
//函数封装
function animate(ele,target){
clearInterval(ele.timer);
var speed = target>ele.offsetLeft?10:-10;
ele.timer = setInterval(function () {
var val = target - ele.offsetLeft;
ele.style.left = ele.offsetLeft + speed + "px";
if(Math.abs(val)<Math.abs(speed)){
ele.style.left = target + "px";
clearInterval(ele.timer);
}
},10)
}
}
</script>
</head>
<body>
<div class="all" id='all'>
<div class="screen" id="screen">
<ul id="ul">
<li><img src="images/01.jpg" width="500" height="200" /></li>
<li><img src="images/02.jpg" width="500" height="200" /></li>
<li><img src="images/03.jpg" width="500" height="200" /></li>
<li><img src="images/04.jpg" width="500" height="200" /></li>
<li><img src="images/05.jpg" width="500" height="200" /></li>
</ul>
<ol>
</ol>
<div id="arr">
<span id="left"><</span>
<span id="right">></span>
</div>
</div>
</div>
</body>
</html>