<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
*{
padding: 0;
margin: 0;
box-sizing: border-box;
}
.wrap{
width: 500px;
height: 300px;
position: relative;
margin: 10px auto;
}
.wrap img{
width: 500px;
height: 300px;
position: absolute;
display: none;
}
.show{
display: block !important;
}
.control{
width: 140px;
height: 45px;
display: flex;
justify-content: space-between;
align-items: center;
position: absolute;
left: 50%;
bottom: 20px;
transform: translate(-50%,0);
}
.control-item{
width: 30px;
height: 30px;
border-radius: 50%;
background-color: rgba(0, 0, 0, 0.5);
}
.active{
background-color: #cccccc;
}
.control-btn{
width: 30px;
height: 70px;
background-color: rgba(0, 0, 0, 0.5);
color: #ffffff;
text-align: center;
line-height: 70px;
position: absolute;
z-index: 10;
top: 50%;
transform: translate(0px,-50%);
}
.letf{
left: 0;
}
.right{
right: 0;
}
</style>
</head>
<body>
<div class="wrap">
<div class="view">
<img class="show" src="images/1.jpg" alt="">
<img src="images/2.jpg" alt="">
<img src="images/3.jpg" alt="">
</div>
<div class="control">
<div class="control-item active"></div>
<div class="control-item"></div>
<div class="control-item"></div>
</div>
<div class="control-dom">
<div class="left control-btn" id="pre"><</div>
<div class="right control-btn" id="next">></div>
</div>
</div>
<script>
var control = document.querySelectorAll('.control-item')
var view = document.querySelectorAll('.view>img')
var pre = document.querySelector('#pre');
var next = document.querySelector('#next')
var index = 0//表示当前显示元素索引
for(var i = 0 ;i<control.length;i++){
// control[i].className = 'control-item'//错误:只能在初始化清空移出
(function(i){
control[i].addEventListener('click',function(){
// 点击小远点后:更改当前显示元素的索引 index
index = i
// 每次添加之前都需要清空一次
for(var j = 0;j<control.length;j++){
control[j].className = 'control-item';
view[j].className = ''
}
control[i].className = 'control-item active'
view[i].className = 'show'
})
})(i)
}
pre.addEventListener('click',function(){
for(var i = 0;i<view.length;i++){
view[i].className=''
control[index].className = 'control-item'
}
--index;
if(index<0){
index = view.length-1
}
view[index].className = 'show'
control[index].className = 'control-item active'
})
next.addEventListener('click',function(){
// 小圆点要切换到下一个
for(var i = 0;i<view.length;i++){
view[i].className=''
control[index].className = 'control-item'
}
++index;
if(index>2){
index = 0
}
view[index].className = 'show'
control[index].className = 'control-item active'
// 图片切换
})
</script>
</body>
</html>
轮播图的切换