console
(function main() {
const container = document.querySelector('.container')
const slider = container.querySelector('.slider');
const btn = {
prev: container.querySelector('.buttons .prev'),
next: container.querySelector('.buttons .next'),
}
btn.prev.addEventListener('click', () => {
let slides = container.querySelectorAll('.slides');
slider.prepend(slides[slides.length - 1]);
});
btn.next.addEventListener('click', () => {
let slides = container.querySelectorAll('.slides');
slider.appendChild(slides[0]);
});
})();
<div class="main">
<div class="container">
<div class="slider">
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/a/3f/3302e58f9a181d2509f3dc0fa68b0jpeg.jpeg');">
<div class="content">
<h2>slide 01</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/1/34/19aa98b1fcb2781c4fba33d850549jpeg.jpeg');">
<div class="content">
<h2>slide 02</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/0/6f/e35ff375812e6b0020b6b4e8f9583jpeg.jpeg');">
<div class="content">
<h2>slide 03</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/9/bb/e27858e973f5d7d3904835f46abbdjpeg.jpeg');">
<div class="content">
<h2>slide 04</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/d/e6/c4d93a3805b3ce3f323f7974e6f78jpeg.jpeg');">
<div class="content">
<h2>slide 05</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/3/28/bbf893f792f03a54408b3b7a7ebf0jpeg.jpeg');">
<div class="content">
<h2>slide 06</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
<div class="slides" style="--img: url('https://fuss10.elemecdn.com/2/11/6535bcfb26e4c79b48ddde44f4b6fjpeg.jpeg');">
<div class="content">
<h2>slide 07</h2>
<p>the quick brown fox jumps over the lazy dog.</p>
</div>
</div>
</div>
<div class="buttons">
<span class="prev"></span>
<span class="next"></span>
</div>
</div>
</div>
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
.main {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
min-width: 100vw;
min-height: 100vh;
margin: 0;
padding: 0;
}
.container {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
width: 100vw;
height: 100vh;
overflow: hidden;
}
.slider {
position: absolute;
inset: 80px 200px 80px 80px;
}
.slider .slides {
--slide-w: 240px;
--slide-gap: 20px;
position: absolute;
top: 50%;
display: flex;
justify-content: flex-start;
align-items: flex-end;
width: var(--slide-w);
height: 320px;
background-image: var(--img);
background-size: cover;
background-position: center;
border-radius: 20px;
box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
transform: translateY(-50%);
transition: 0.5s;
}
.slider .slides:nth-child(-n+2) {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-size: cover;
box-shadow: 0 25px 50px rgba(0, 0, 0, 0);
transform: translateY(0);
}
.slider .slides:nth-child(n+3) {
--offset-x: calc(var(--i) * var(--slide-w)) + ((var(--i) - 1) * var(--slide-gap));
left: calc(50% + var(--offset-x));
background-size: cover;
}
.slider .slides:nth-child(3) { --i: 1; }
.slider .slides:nth-child(4) { --i: 2; }
.slider .slides:nth-child(5) { --i: 3; }
.slider .slides:nth-child(6) { --i: 4; }
.slider .slides:nth-child(7) { --i: 5; }
.slider .slides .content {
max-width: 600px;
padding: 40px;
font-size: 18px;
color: #fff;
visibility: hidden;
opacity: 0;
text-transform: capitalize;
transition: 0.25s;
transition-delay: 0px;
transform: translateY(40px);
}
.slider .slides .content h2 {font-size: 4em;}
.slider .slides:nth-child(-n+2) .content {
visibility: visible;
opacity: 1;
transition-delay: 0.5s;
transform: translateY(0);
}
.buttons {
position: absolute;
bottom: 15px;
display: flex;
gap: 20px;
}
.buttons span {
position: relative;
display: flex;
justify-content: center;
align-items: center;
width: 50px;
height: 50px;
background-color: #333;
border-radius: 50%;
cursor: pointer;
}
.buttons span:active {
opacity: 0.5;
}
.buttons span::before {
content: '';
position: absolute;
width: 15px;
height: 15px;
border-top: 4px solid rgba(255, 255, 255, 1);
border-left: 4px solid rgba(255, 255, 255, 1);
}
.buttons span.prev::before {
transform: rotate(315deg) translate(2px, 2px);
}
.buttons span.next::before {
transform: rotate(135deg) translate(2px, 2px);
}
@media (max-width: 900px) {
.slider {
position: absolute;
inset: 40px 40px 200px 40px;
}
.slider .slides {
--slide-w: 100px;
top: initial;
bottom: -170px;
height: 100px;
}
.slider .slides:nth-child(-n+2) {
top: initial;
bottom: 0;
}
.slider .slides:nth-child(n+3) {
left: calc((var(--i) - 1) * (var(--slide-w) + var(--slide-gap)));
}
}