vue实现走马灯显示文字效果

完整示例

将 CSS 和 HTML 结合起来,一个完整的跑马灯效果如下:

HTML:

复制代码
<div class="marquee-container">
  <span class="marquee-text">这是一段很长很长的跑马灯文字,它会一直向左边滚动,永不停歇!</span>
</div>

CSS:

复制代码
/* 定义动画 */
@keyframes marquee {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}

/* 应用样式的类 */
.marquee-text {
  display: inline-block;
  white-space: nowrap;
  color: red;
  animation: marquee 100s linear infinite;
}

/* 可选:给容器设置宽度和溢出隐藏,以获得更好的视觉效果 */
.marquee-container {
  width: 300px; /* 容器宽度 */
  overflow: hidden; /* 隐藏溢出的文字 */
  border: 1px solid #ccc;
  padding: 10px;
}

最终效果"这是一段很长很长的跑马灯文字..."这段文字会在 300px 宽的容器内,以恒定的速度从右向左无限循环滚动,颜色为红色。

样式解释:

.marquee-text { display: inline-block; white-space: nowrap; color: red; animation: marquee 100s linear infinite; }这段代码是什么意思

这段 CSS 代码定义了一个名为 .marquee-text的类选择器,用于创建一个无限循环的水平滚动文字效果(跑马灯效果)。

让我逐行解析:


1. .marquee-text { ... }

这是 CSS 的类选择器 ,表示这套样式规则将应用于所有带有 class="marquee-text"的 HTML 元素。


2. display: inline-block;

  • 作用 :将元素的显示类型设置为内联块级元素

  • 为什么需要inline-block兼具 inline(不独占一行)和 block(可以设置宽高等尺寸属性)的特性。这对于跑马灯效果很重要,因为它允许元素在一行内流动,同时又可以承载动画。


3. white-space: nowrap;

  • 作用 :强制文本内容不换行,始终在同一行内显示。

  • 为什么需要:这是跑马灯效果的核心。如果文字自动换行,就无法形成连续滚动的效果。所有文字会被压缩或溢出容器,保持为一长串。


4. color: red;

  • 作用:将文字颜色设置为红色。

  • 说明:这是一个普通的样式属性,与跑马灯效果本身无关,只是为了视觉效果。


5. animation: marquee 100s linear infinite;

这是实现动画效果的关键属性,它简写了多个动画子属性。

  • animation-name: marquee;:指定要使用的 @keyframes 动画规则​ 的名称。这个规则(在代码其他地方定义)描述了元素在动画过程中如何变化。

  • animation-duration: 100s;:动画完成一个周期所需的总时间为 100 秒。时间越长,滚动越慢。

  • animation-timing-function: linear;:动画的速度曲线为线性,意味着从开始到结束速度恒定,没有加速或减速。

  • animation-iteration-count: infinite;:动画无限次重复播放,永远不会停止。

  • 一个典型的 marquee动画定义如下:

    复制代码
    @keyframes marquee {
      0% {
        transform: translateX(0%); /* 动画开始时,元素在初始位置 */
      }
      100% {
        transform: translateX(-100%); /* 动画结束时,元素向左移动了自身宽度的 100% */
      }
    }

    这个 keyframes 的解释

  • 0%:动画开始时,元素的位置不变。

  • 100%:动画结束时,元素通过 transform: translateX(-100%)向左移动了它自身宽度的 100%。这确保了整个文本行都能从视图中移出,为无缝循环做好准备。

相关推荐
超哥--1 小时前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
Cutecat_4 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
dsyyyyy11014 小时前
JavaScript变量
开发语言·javascript·ecmascript
qq_422152575 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen5 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee1866 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct9786 小时前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客6 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖6 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty7 小时前
Vue2与Vue3之间API差异
前端·javascript·vue.js