CSS3 实现文本与图片横向无限滚动动画

文章目录

  • [1. 实现效果](#1. 实现效果)
  • 2.html结构
  • [3. css代码](#3. css代码)

1. 实现效果

gif录屏比较卡,实际很湿滑,因为是css动画实现的

2.html结构

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Infinite Scrolling Animation</title>
</head>

<body>
  <div class="scroll" style="--t: 20s">
    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>

    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>
  </div>

  <div class="scroll" style="--t: 30s">
    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>

    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>
  </div>

  <div class="scroll" style="--t: 10s">
    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>

    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>
  </div>

  <div class="scroll" style="--t: 35s">
    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>

    <div>
      <span>HTML</span>
      <span>CSS</span>
      <span>JavaScript</span>
      <span>Vue</span>
      <span>React</span>
      <span>Figma</span>
      <span>Photoshop</span>
    </div>
  </div>

  <div class="scroll img-box" style="--t: 25s">
    <div>
      <div class="bg" style="--r: 0;">1</div>
      <div class="bg" style="--r: 40;">2</div>
      <div class="bg" style="--r: 80;">3</div>
      <div class="bg" style="--r: 120;">4</div>
      <div class="bg" style="--r: 160;">5</div>
      <div class="bg" style="--r: 200;">6</div>
      <div class="bg" style="--r: 240;">7</div>
      <div class="bg" style="--r: 280;">8</div>
      <div class="bg" style="--r: 320;">9</div>
    </div>

    <div>
      <div class="bg" style="--r: 0;">1-1</div>
      <div class="bg" style="--r: 40;">2-1</div>
      <div class="bg" style="--r: 80;">3-1</div>
      <div class="bg" style="--r: 120;">4-1</div>
      <div class="bg" style="--r: 160;">5-1</div>
      <div class="bg" style="--r: 200;">6-1</div>
      <div class="bg" style="--r: 240;">7-1</div>
      <div class="bg" style="--r: 280;">8-1</div>
      <div class="bg" style="--r: 320;">9-1</div>
    </div>
  </div>
</body>

</html>

3. css代码

css 复制代码
@import url('https://fonts.googleapis.com/css?family=Poppins:400,600,700,800&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Poppins', sans-serif;
}

body {
  min-height: 100vh;
  background-color: #222;
  color: #fff;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;  
}

.scroll {
  position: relative;

  display: flex;
  width: 700px;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #fff 20%, #fff 80%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #fff 20%, #fff 80%, transparent);
}

.scroll > div span {
  display: inline-block;
  margin: 10px;
  padding: 5px 10px;
  background-color: #333;
  border-radius: 5px;

  letter-spacing: 0.2em;
  text-transform: uppercase;

  cursor: pointer;
  transition: background-color 0.5s;
}
.scroll > div span:hover {
  background-color: #4caf50;
}

.img-box {
  display: flex;
  column-gap: 10px;
}
.img-box > div,
.img-box > div .bg {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.img-box .bg {
  width: 150px;
  height: 150px;
  background-color: #ff3e3e;
  filter: hue-rotate(calc(var(--r) * 1deg));
  
  cursor: pointer;
  transition: filter 0.5s;
}

.scroll > div {
  white-space: nowrap;
  animation: animate var(--t) linear infinite;
  animation-delay: calc(var(--t) * -1);
}
@keyframes animate {
  0% {
    transform: translateX(100%);
  }

  100% {
    transform: translateX(-100%);
  }
}

.scroll > div:nth-child(2) {
  animation: animate2 var(--t) linear infinite;
  animation-delay: calc(var(--t) / -2);
}
@keyframes animate2 {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-200%);
  }
}

.scroll:hover > div {
  animation-play-state: paused;
}


@media screen and (max-width: 768px) {
  .scroll {
    width: 95vw;
  }

  .scroll > div span {
    background-color: #4caf50;
  }

  .img-box .bg {
    width: 15vw;
    height: 15vw;
  }
}
相关推荐
皮蛋瘦肉粥_1212 天前
pink老师html5+css3day02
前端·css3·html5
▍ 小太阳 ☼2 天前
blender布局工作区突然变得很卡
动画·blender
qianmo20212 天前
基于any2web+deepseek实现对三角函数定义的理解
css·html·css3
我不是程序媛lisa4 天前
前端正确处理“文字溢出”的思路与最佳实践
前端·css3
患得患失9499 天前
【ThreeJs】【HTML载入】Three.js 中的 CSS2DRenderer 与 CSS3DRenderer 全面解析
javascript·html·css3
!win !14 天前
不定高元素动画实现方案(中)
前端·动画
!win !14 天前
不定高元素动画实现方案(上)
前端·动画
少年阿闯~~19 天前
CSS3的新特性
前端·javascript·css3
恶猫19 天前
javascript文本长度检测与自动截取,用于标题长度检测
javascript·css·css3·js·自动检测·文本长度
degree52020 天前
CSS :has() 选择器详解:为什么它是“父选择器”?如何实现真正的容器查询?
前端·css·css3