前端css走马灯式图片轮播

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Continuous Carousel</title>
  <style>
    body {
      margin: 0;
      overflow: hidden;
    }

    #carousel-container {
      white-space: nowrap;
      overflow: hidden;
      position: relative;
    }

    .carousel-item {
      display: inline-block;
      margin-right: 5vw; /* 图片间隔,使用vw单位,可根据需要调整 */
    }

    .carousel-inner {
      display: inline-block;
      white-space: nowrap;
      animation: marquee 20s linear infinite; /* 调整滚动速度,例如20s */
    }

    @keyframes marquee {
      0% {
        transform: translateX(0);
      }
      100% {
        transform: translateX(-100%); /* 从左向右滚动 */
      }
    }
  </style>
</head>
<body>
  <div id="carousel-container">
    <div class="carousel-inner" id="sequence-1"></div>
    <div class="carousel-inner" id="sequence-2"></div>
  </div>

  <script>
    document.addEventListener('DOMContentLoaded', () => {
      const container = document.getElementById('carousel-container');
      const sequence1 = document.getElementById('sequence-1');
      const sequence2 = document.getElementById('sequence-2');

      // 创建图片序列
      const createImageSequence = (target) => {
        for (let i = 1; i <= 7; i++) {
          const item = document.createElement('div');
          item.classList.add('carousel-item');
          const img = document.createElement('img');
          img.src = `image${i}.jpg`;
          img.alt = `Image ${i}`;
          item.appendChild(img);
          target.appendChild(item);
        }
      };

      // 插入两个图片序列
      createImageSequence(sequence1);
      createImageSequence(sequence2);

      // Optional: 调整滚动速度
      const duration = 20; // in seconds
      container.style.animationDuration = `${duration}s`;
    });
  </script>
</body>
</html>
相关推荐
万少1 小时前
使用Trae轻松安装openclaw的教程-附带免费token
前端·openai·ai编程
浪浪山_大橙子2 小时前
OpenClaw 十分钟快速,安装与接入完全指南 - 推荐使用trae 官方 skills 安装
前端·人工智能
忆江南2 小时前
iOS 可视化埋点与无痕埋点详解
前端
离开地球表面_992 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
_柳青杨2 小时前
跨域获取 iframe 选中文本?自己写个代理中间层,再也不求后端!
前端
比尔盖茨的大脑2 小时前
事件循环底层原理:从 V8 引擎到浏览器实现
前端·javascript·面试
天才熊猫君2 小时前
Vue3 命令式弹窗原理和 provide/inject 隔离机制详解
前端
bluceli2 小时前
Vue 3 Composition API深度解析:构建可复用逻辑的终极方案
前端·vue.js
程序员ys2 小时前
前端权限控制设计
前端·vue.js·react.js
忆江南2 小时前
Flutter GetX 深入浅出详解
前端