全屏轮播
现在我们要做的全屏轮播点击按钮切换下一个图片创建一个HTML写入每页的内容
<div class="slider"> <div class="slide"> <div class="content"> <h1>第一页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> <div class="slide current"> <div class="content"> <h1>第二页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> <div class="slide"> <div class="content"> <h1>第三页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> <div class="slide"> <div class="content"> <h1>第四页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> <div class="slide"> <div class="content"> <h1>第五页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> <div class="slide"> <div class="content"> <h1>第六页</h1> <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Possimus corrupti hic doloremque in dolorem sint qui! Facere, optio ratione? Placeat!</p> </div> </div> </div> <div class="buttons"> <button id="prev"><i class="fas fa-arrow-left"></i></button> <button id="next"><i class="fas fa-arrow-right"></i></button> </div> <script src="./main.js"></script>
添加css样式,插入切换的图片
/* reset */ * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; background-color: #333; color: #fff; line-height: 1.6; } .slider { position: relative; overflow: hidden; height: 100vh; width: 100vw; } .slide { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 0.4s ease-in-out; } .slide.current { opacity: 1; } /* background images */ .slide:first-child { background: url(./img/1.jpg) no-repeat center center/cover; } .slide:nth-child(2) { background: url(./img/2.jpg) no-repeat center center/cover; } .slide:nth-child(3) { background: url(./img/3.jpg) no-repeat center center/cover; } .slide:nth-child(4) { background: url(./img/4.jpg) no-repeat center center/cover; } .slide:nth-child(5) { background: url(./img/5.jpg) no-repeat center center/cover; } .slide:nth-child(6) { background: url(./img/6.jpg) no-repeat center center/cover; } /* content */ .slide .content { position: absolute; bottom: 70px; left: -600px; width: 600px; opacity: 0; background-color: rgba(255, 255, 255, 0.8); color: #333; padding: 35px; } .slide .content h1 { margin-bottom: 10px; } .slide.current .content { opacity: 1; transform: translateX(600px); transition: all 0.7s ease-in-out 0.3s; } .buttons button#prev { position: absolute; top: 50%; left: 15px; } .buttons button#next { position: absolute; top: 50%; right: 15px; } .buttons button { border: 2px solid #fff; background-color: transparent; color: #fff; cursor: pointer; padding: 13px 15px; border-radius: 50%; outline: none; } .buttons button:hover { background-color: #fff; color: #333; } /* media queries */ @media (max-width: 500px) { .slide .content { bottom: -300px; left: 0; width: 100%; } .slide.current .content { transform: translateY(-300px); } }
页面内容 css样式给完之后我们需要写一个js文件
const slides = document.querySelectorAll('.slide') const next = document.querySelector('#next') const prev = document.querySelector('#prev') const nextSlide = function () { //get current class const current = document.querySelector('.current') if (current.nextElementSibling) { //add current to next sibling current.nextElementSibling.classList.add('current') } else { //add current to start slides[0].classList.add('current') } //clear current setTimeout(() => current.classList.remove('current')) } const preSlide = function () { //get current class const current = document.querySelector('.current') if (current.previousElementSibling) { //add current to prev sibling current.previousElementSibling.classList.add('current') } else { //add current to end slides[slides.length - 1].classList.add('current') } //clear current setTimeout(() => current.classList.remove('current')) } //button event next.addEventListener('click', function () { nextSlide() }) prev.addEventListener('click', function () { prevSlide() })