纯 CSS 实现 超长内容滚动播放。

需求:文案来回在指定区域内水平滚动,并且在头尾处停留一段时间 ​

以vue为例,封装一个通用组件

javascript 复制代码
<template>
  <view class="box">
    <view class="scroll-wrap">
      <view class="scroll-item" :style="{color:color,fontWeight:fontWeight, fontSize:`${fontSize}rpx`}">
        {{ text}}
      </view>
    </view>
  </view>
</template>

<script>
  // 使用需要外层套一个div给盒子宽度
  export default {
    props: {
      // 滚动的文本
      text: {
        type: String,
        default: '',
      },
      // 颜色
      color: {
        type: String,
        default: '#333333',
      },
      // 文字大小
      fontSize: {
        type: String,
        default: '24',
      },
      fontWeight: {
        type: String,
        default: '500',
      }
    },
    data() {
      return {};
    },
    mounted() {},
    methods: {},
  };
</script>

<style lang="scss" scoped>
  .box {
    width: 100%;
    // border: 1px solid;
  }

  .scroll-wrap {
    max-width: 100%;
    display: inline-block;
    vertical-align: top;
    overflow: hidden;
    white-space: nowrap;

  }

  .scroll-item {

    animation: scroll linear 4s alternate infinite;
    float: left;
  }

  @keyframes scroll {
    0% {
      margin-left: 0;
      transform: translateX(0);
    }

    10% {
      margin-left: 0;
      transform: translateX(0);
    }

    90% {
      margin-left: 100%;
      transform: translateX(-100%);
    }

    100% {
      margin-left: 100%;
      transform: translateX(-100%);
    }
  }
</style>

使用组件

javascript 复制代码
<view style="width:200rpx;">
  <text-scroll :text="我很长啊我很长啊我很长啊我很长啊我很长啊" fontSize="32" fontWeight="600"></text-scroll>
</view>

简单解释一下当前 animation 的属性

  • animation-name:所使用的 @keyframes 的名称 scroll
  • animation-timing-function:动画的速度曲线,linear 表示匀速
  • animation-duration:规定完成动画所花费的时间为 4s
  • animation-direction:是否应该轮流反向播放动画,alternate 表示在偶数次会反向播放
  • animation-iteration-count:定义动画的播放次数,infinite 表示无限次
相关推荐
小林ixn8 小时前
你以为你懂 + 号?看完这篇 Bun + TS 实战,才发现以前全写错了
前端·javascript·typescript
namexingyun8 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
Zyed8 小时前
[STM32]Day15读写FLASH+读取ID
前端·stm32·性能优化
jvxiao9 小时前
你真的懂作用域吗?从编译原理角度深度 JS 的作用域
前端·javascript
Darling噜啦啦9 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
星栈9 小时前
Rust + Makepad 应用怎么打包发布:Windows、macOS、Linux 全平台交付
前端·rust
Aolith9 小时前
React 路由守卫:我用一个组件替代了 Vue 的 beforeEach
前端·react.js
Daybreak9 小时前
从 PDD、DDD、SDD 到 TDD:我是如何用一套 Agent 工程方法论推进 My-Notion 的
前端
HjhIron10 小时前
从零实现一个待办事项应用:前端必学的Ajax与Node.js实战
前端·后端
yingyima10 小时前
JavaScript 正则表达式:从零开始的实战对比
前端