html+css+js实现轮播图

实现效果:

HTML部分

html 复制代码
<div class="carousel">
    <div class="carousel-wrapper">
      <img src="./image/1.png" alt="">
    </div>
    <ul class="carousel-indictor">
      <li class="active" data-id="0"></li>
      <li data-id="1"></li>
      <li data-id="2"></li>
      <li data-id="3"></li>
    </ul>
    <div class="toggle">
      <button class="prev"><</button>
      <button class="next">></button>
    </div>
  </div>

CSS部分

css 复制代码
<style>
    *{
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }
    li{
      list-style: none;
    }
    button{
      border: none;
      outline: none;
    }
    .carousel{
      position: relative;
      width: 700px;
      height: 300px;
      margin: 50px auto;
    }
    .carousel-wrapper{
      width: 700px;
      height: 300px;
    }
    .carousel-wrapper img{
      width: 100%;
      height: 100%;
    }
    .carousel-indictor{
      position: absolute;
      bottom: 30px;
      left: 150px;
      width: 400px;
      height: 5px;
      display: flex;
      justify-content: space-between;
    } 
    .carousel-indictor li{
      width: 85px;
      background-color: rgba(235, 239, 243);
    }
    .carousel-indictor li.active{
      background-color: #fff;
    }
    .toggle button{
      display: none;
      width: 50px;
      height: 50px;
      background-color: rgba(191, 201, 212,0.5);
      border-radius: 50%;
      color: #fff;
      font-size: 25px;
    }
    .carousel:hover .toggle button{
      display: block;
    }
    .toggle button:hover{
      background-color: rgb(125, 140, 161);
      cursor: pointer;
    }
    .toggle .prev{
      top: 125px;
      left: 30px;
      position: absolute;
    }
    .toggle .next{
      top: 125px;
      right: 30px;
      position: absolute;
    }
  </style>

JS部分

javascript 复制代码
<script>
    const data = [
    {url:'./image/1.png'},
    {url:'./image/2.png'},
    {url:'./image/3.png'},
    {url:'./image/4.png'}
    ]
    const img = document.querySelector('.carousel-wrapper img')
    // 1.右键
    const next = document.querySelector('.next')
    let i = 0
    next.addEventListener('click',function(){
      // console.log(data[i]);
      i++
      i = i>3 ? 0 : i

      img.src=data[i].url
      document.querySelector('.carousel-indictor .active').classList.remove('active')
      document.querySelector(`.carousel-indictor li:nth-child(${i+1})`).classList.add('active')
    })

    // 2.左键
    const prev = document.querySelector('.prev')
    prev.addEventListener('click',function(){
      i--
      i = i<0 ? i=3 : i
      // 图像
      img.src=data[i].url
      // 下划线
      document.querySelector('.carousel-indictor .active').classList.remove('active')
      document.querySelector(`.carousel-indictor li:nth-child(${i+1})`).classList.add('active')
    })

    // 3.定时器
    let timerId = setInterval(function(){
      next.click()
    },1000)
    const carousel = document.querySelector('.carousel')
    carousel.addEventListener('mouseenter',function(){
      clearInterval(timerId)
    })
    carousel.addEventListener('mouseleave',function(){
        timerId= setInterval(function(){
        next.click()
      },1000)
    })

    // 4.经过li时,也对应跳转
    const ul = document.querySelector('.carousel-indictor')
    ul.addEventListener('click',function(e){
      if(e.target.tagName === 'LI'){
        document.querySelector('.carousel-indictor .active').classList.remove('active')
        e.target.classList.add('active')
        // console.log(e.target.dataset.id);
        const i = e.target.dataset.id
        img.src=data[e.target.dataset.id].url
      }
    })
  </script>
相关推荐
古一|1 分钟前
Vue3中ref与reactive实战指南:使用场景与代码示例
开发语言·javascript·ecmascript
peachSoda73 分钟前
封装一个不同跳转方式的通用方法(跳转外部链接,跳转其他小程序,跳转半屏小程序)
前端·javascript·微信小程序·小程序
熊猫钓鱼>_>31 分钟前
TypeScript前端架构与开发技巧深度解析:从工程化到性能优化的完整实践
前端·javascript·typescript
JYeontu1 小时前
肉眼难以分辨 UI 是否对齐,写个插件来辅助
前端·javascript
fox_1 小时前
别再踩坑!JavaScript的this关键字,一次性讲透其“变脸”真相
前端·javascript
写不来代码的草莓熊2 小时前
vue前端面试题——记录一次面试当中遇到的题(9)
前端·javascript·vue.js
urhero3 小时前
工作事项管理小工具——HTML版
前端·html·实用工具·工作事项跟踪·任务跟踪小工具·本地小程序
郝学胜-神的一滴3 小时前
Three.js光照技术详解:为3D场景注入灵魂
开发语言·前端·javascript·3d·web3·webgl
m0dw3 小时前
vue懒加载
前端·javascript·vue.js·typescript
cecyci5 小时前
如何实现AI聊天机器人的打字机效果?
前端·javascript