SOURCE

console 命令行工具 X clear

                    
>
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);
}

/* Responsive */
@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)));
    }
}