简单实现文字滚动效果-CSS版本

先看看效果

话不多说直接上代码

html 复制代码
<template>
  <div class="main">
    <div class="scroll-region">
      <div class="swiper-scroll-content">
        <span class="list-btn" v-for="(item, index) in overviewList" :key="index">
          {{ item }}
        </span>
      </div>
    </div>
  </div>
</template>
js 复制代码
<script>
export default {
  data() {
    return {
      overviewList: [
        '富强', '民主', '文明', '和谐', '自由', '平等', '公正', '法治', '爱国', '敬业', '诚信', '友善', '富强', '民主', '文明', '和谐', '自由', '平等', '公正', '法治',
      ]
    }
  }
}
</script>
css 复制代码
<style scoped>
.main {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 100px 0 0 0;
  background: #2f44e6;
}
.scroll-region {
  width: 60%;
  overflow: hidden;
}
@keyframes roll {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-153%);
  }
}
.swiper-scroll-content {
  display: flex;
  align-items: center;
  white-space: nowrap;
  animation: roll 25s infinite linear;
}
@keyframes animated-border {
  0% {
    box-shadow: 0 0 0 0 rgba(255,255,255,0.4);
  }
  100% {
    outline: 5px solid rgba(255,255,255,0);
    outline-offset: -5px;
  }
}
.list-btn {
  padding: 10px 20px;
  margin: 0 11px;
  color: #6DFFFF;
  border-radius: 20px;
  animation: animated-border 1.5s infinite;
  font-family: Arial;
  font-size: 18px;
  line-height: 30px;
  font-weight: bold;
}
</style>

主要修改点有两个:

  1. transform: translateX(-153%),这里需要自己根据情况更改衔接,保证轮播是连贯不断地。
  2. 通过overviewList的尾部添加重复文本,配合transform来实现轮播连贯。
相关推荐
JustHappy7 小时前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
何中应7 小时前
nvm安装使用
前端·node.js·开发工具
雯0609~7 小时前
hiprint:实现项目部署与打印3-vue版本-独立出模板设计与模板打印页面
前端·vue.js·arcgis
杜子不疼.7 小时前
【Linux】教你在 Linux 上搭建 Web 服务器,步骤清晰无门槛
linux·服务器·前端
程序员Agions8 小时前
useMemo、useCallback、React.memo,可能真的要删了
前端·react.js
滕青山8 小时前
Vue项目BMI计算器技术实现
前端·vue.js
子兮曰8 小时前
深入浏览器指纹:Canvas、WebGL、Audio是如何暴露你的身份的?
前端·浏览器·canvas
月亮补丁8 小时前
AntiGravity只能生成 1:1 图片?一招破解尺寸限制
前端
何中应8 小时前
MindMap部署
前端·node.js
NAGNIP8 小时前
程序员效率翻倍的快捷键大全!
前端·后端·程序员