Malunan个人博客|IT技术博客 Malunan个人博客|IT技术博客
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Lunan Ma

升职加薪搞钱~
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 技术文档

    • Git使用手册
    • Markdown使用教程
    • npm常用命令
    • 移动端兼容问题
    • 常用cmd命令
    • npm packageJson属性详解
    • yaml语言教程
    • Git修改分支名
    • javaScript-时间相加,超过24小时继续累加
    • 获取视频文件第一帧
    • 前端获取文件下载进度
    • 前端获取上传的视频图片详细信息
    • 解决拖拽时,如果元素内有input,无法选中文本的问题
    • css点击穿透
    • vue插槽传参
    • 谷歌浏览器的kiosk模式
    • 前台下载后台返的二进制文件流
    • css实现无缝切换跑马灯样式
      • 需求
      • 演示
      • 实现
    • 前端优化规范
    • 懒加载+无感删除list思路
  • GitHub技巧

  • Nodejs

  • 博客搭建

  • 脚本

  • 技术
  • 技术文档
MaLunan
2024-03-05
目录
需求
演示
实现

css实现无缝切换跑马灯样式

# 需求

实现跑马灯样式,多张图片从左往右依次循环播放,播放完毕后从第一张继续播放

# 演示

演示

# 实现

公式为 子元素宽 * 一屏展示子元素的宽(也就是 父元素宽 / 子元素宽) 比如下面例子 子元素宽200px * 一屏展示子元素的宽 ( 父元素宽 / 子元素宽) 800/200 =4
也就是 200*4 = 800
800作为移动的距离,然后再重新从第一个元素开始,这样从视觉上看,就是无缝切换

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
  .box{
    width: 800px;
    overflow: hidden;
  }
  .card-box{
    display: flex;
    animation: move 5s linear infinite backwards;
  }
   .card{
    border: 1px solid sienna;
    display: block;
    width: 200px;
    height: 100px;
    flex-shrink: 0;
    
   }
   @keyframes move {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-800px);
    }
  }
</style>
<body>
    <div class="box">
      <div class="card-box">
        <div class="card">
          1
        </div>
        <div class="card">
          2
        </div>
        <div class="card">
          3
        </div>
        <div class="card">
          4
        </div>
        <div class="card">
          5
        </div>
        <div class="card">
          6
        </div>
        <div class="card">
          1
        </div>
        <div class="card">
          2
        </div>
        <div class="card">
          3
        </div>
        <div class="card">
          4
        </div>
      </div>
    </div>
     
</body>
<script>

</script>
</html>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
编辑 (opens new window)
上次更新: 2024/03/06, 10:23:10
前台下载后台返的二进制文件流
前端优化规范

← 前台下载后台返的二进制文件流 前端优化规范→

最近更新
01
懒加载+无感删除list思路
11-12
02
移动端兼容问题
11-12
03
前端优化规范
03-25
更多文章>
Theme by Vdoing | Copyright © 2019-2025 LuNan Ma | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式