原来利用纯CSS也能实现文字轮播与图片轮播!

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯css也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

原来利用纯CSS也能实现文字轮播与图片轮播!

今天,分享一个实际业务中能够用得上的动画技巧。【推荐学习:css视频教程】

巧用逐帧动画,配合补间动画实现一个无限循环的轮播效果,像是这样:

原来利用纯CSS也能实现文字轮播与图片轮播!

立即学习“前端免费学习笔记(深入)”;

看到上述示意图,有同学不禁会发问,这不是个非常简单的位移动画么?

我们来简单分析分析,从表面上看,确实好像只有元素的 transform: translate() 在位移,但是注意,这里有两个难点:

这是个无限轮播的效果,我们的动画需要支持任意多个元素的无限轮播切换

因为是轮播,所以,运行到最后一个的时候,需要动画切到第一个元素

到这里,你可以暂停思考一下,如果有 20 个元素,需要进行类似的无限轮播播报,使用 CSS 实现,你会怎么去做呢?

逐帧动画控制整体切换

首先,我需要利用到逐帧动画效果,也被称为步骤缓动函数,利用的是 animation-timing-function 中,的 steps,语法如下:

{    /* Keyword values */    animation-timing-function: step-start;    animation-timing-function: step-end;    /* Function values */    animation-timing-function: steps(6, start)    animation-timing-function: steps(4, end);}

如果你对 steps 的语法还不是特别了解,强烈建议你先看看我的这篇文章 — 深入浅出 CSS 动画,它对理解本文起着至关重要的作用。

好的,还是文章以开头的例子,假设我们存在这样 HTML 结构:

  • Lorem ipsum 1111111
  • Lorem ipsum 2222222
  • Lorem ipsum 3333333
  • Lorem ipsum 4444444
  • Lorem ipsum 5555555
  • Lorem ipsum 6666666

首先,我们实现这样一个简单的布局:

原来利用纯CSS也能实现文字轮播与图片轮播!

在这里,要实现轮播效果,并且是任意个数,我们可以借助 animation-timing-function: steps()

:root {  // 轮播的个数  --s: 6;  // 单个 li 容器的高度  --h: 36;  // 单次动画的时长  --speed: 1.5s;}.g-container {  width: 300px;  height: calc(var(--h) * 1px);}ul {  display: flex;  flex-direction: column;  animation: move calc(var(--speed) * var(--s)) steps(var(--s)) infinite;}ul li {  width: 100%;}@keyframes move {  0% {    transform: translate(0, 0);  }  100% {    transform: translate(0, calc(var(--s) * var(--h) * -1px));  }}

别看到上述有几个 CSS 变量就慌了,其实很好理解:

calc(var(--speed) * var(--s)):单次动画的耗时 * 轮播的个数,也就是总动画时长

steps(var(--s)) 就是逐帧动画的帧数,这里也就是 steps(6),很好理解

calc(var(--s) * var(--h) * -1px)) 单个 li 容器的高度 * 轮播的个数,其实就是 ul 的总体高度,用于设置逐帧动画的终点值

上述的效果,实际如下:

原来利用纯CSS也能实现文字轮播与图片轮播!

如果给容器添加上 overflow: hidden,就是这样的效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

这样,我们就得到了整体的结构,至少,整个效果是循环的。

但是由于只是逐帧动画,所以只能看到切换,但是每一帧之间,没有过渡动画效果。所以,接下来,我们还得引入补间动画。

利用补间动画实现两组数据间的切换

我们需要利用补间动画,实现动态的切换效果。

这一步,其实也非常简单,我们要做的,就是将一组数据,利用 transform,从状态 A 位移到 状态 B。

单独拿出一个来演示的话,大致的代码如下:

  • Lorem ipsum 1111111
  • Lorem ipsum 2222222
  • Lorem ipsum 3333333
  • Lorem ipsum 4444444
  • Lorem ipsum 5555555
  • Lorem ipsum 6666666
:root {  --h: 36;  --speed: 1.2s;}ul li {  height: 36px;  animation: liMove calc(var(--speed)) infinite;}@keyframes liMove {  0% {    transform: translate(0, 0);  }  80%,  100%  {    transform: translate(0, -36px);  }}

非常简单的一个动画:

bgg1

基于上述效果,我们如果把一开始提到的 逐帧动画 和这里这个 补间动画 结合一下,ul 的整体移动,和 li 的 单个移动叠在在一起:

:root {  // 轮播的个数  --s: 6;  // 单个 li 容器的高度  --h: 36;  // 单次动画的时长  --speed: 1.5s;}.g-container {  width: 300px;  height: calc(var(--h) * 1px);}ul {  display: flex;  flex-direction: column;  animation: move calc(var(--speed) * var(--s)) steps(var(--s)) infinite;}ul li {  width: 100%;  animation: liMove calc(var(--speed)) infinite;}@keyframes move {  0% {    transform: translate(0, 0);  }  100% {    transform: translate(0, calc(var(--s) * var(--h) * -1px));  }}@keyframes liMove {  0% {    transform: translate(0, 0);  }  80%,  100%  {    transform: translate(0, calc(var(--h) * -1px));  }}

就能得到这样一个效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

Wow,神奇的化学反应产生了!基于 逐帧动画补间动画 的结合,我们几乎实现了一个轮播效果。

当然,有一点瑕疵,可以看到,最后一组数据,是从第六组数据 transform 移动向了一组空数据:

原来利用纯CSS也能实现文字轮播与图片轮播!

末尾填充头部第一组数据

实际开发过轮播的同学肯定知道,这里,其实也很好处理,我们只需要在末尾,补一组头部的第一个数据即可:

改造下我们的 HTML:

  • Lorem ipsum 1111111
  • Lorem ipsum 2222222
  • Lorem ipsum 3333333
  • Lorem ipsum 4444444
  • Lorem ipsum 5555555
  • Lorem ipsum 6666666
  • Lorem ipsum 1111111

这样,我们再看看效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

Beautiful!如果你还有所疑惑,我们给容器加上 overflow: hidden,实际效果如下,通过额外添加的最后一组数据,我们的整个动画刚好完美的衔接上,一个完美的轮播效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

立即学习“前端免费学习笔记(深入)”;

完整的代码,你可以戳这里:CodePen Demo — Vertical Infinity Loophttps://codepen.io/Chokcoco/pen/RwQVByx

横向无限轮播

当然,实现了竖直方向的轮播,横向的效果也是一样的。

并且,我们可以通过在 HTML 结构中,通过 style 内填写 CSS 变量值,传入实际的 li 个数,以达到根据不同 li 个数适配不同动画:

  • Lorem ipsum 1111111
  • Lorem ipsum 2222222
  • Lorem ipsum 3333333
  • Lorem ipsum 4444444
  • Lorem ipsum 5555555
  • Lorem ipsum 6666666
  • Lorem ipsum 1111111

整个动画的 CSS 代码基本是一致的,我们只需要改变两个动画的 transform 值,从竖直位移,改成水平位移即可:

:root {  --w: 300;  --speed: 1.5s;}.g-container {  width: calc(--w * 1px);  overflow: hidden;}ul {  display: flex;  flex-wrap: nowrap;   animation: move calc(var(--speed) * var(--s)) steps(var(--s)) infinite;}ul li {  flex-shrink: 0;  width: 100%;  height: 100%;  animation: liMove calc(var(--speed)) infinite;}@keyframes move {  0% {    transform: translate(0, 0);  }  100% {    transform: translate(calc(var(--s) * var(--w) * -1px), 0);  }}@keyframes liMove {  0% {    transform: translate(0, 0);  }  80%,  100%  {    transform: translate(calc(var(--w) * -1px), 0);  }}

这样,我们就轻松的转化为了横向的效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

完整的代码,你可以戳这里:CodePen Demo — Horizontal Infinity Loop

https://codepen.io/Chokcoco/pen/JjpNBXY

轮播图?不在话下

OK,上面的只是文字版的轮播,那如果是图片呢?

没问题,方法都是一样的。基于上述的代码,我们可以轻松地将它修改一下后得到图片版的轮播效果。

代码都是一样的,就不再列出来,直接看看效果:

原来利用纯CSS也能实现文字轮播与图片轮播!

完整的代码,你可以戳这里:CodePen Demo — Horizontal Image Infinity Loop

https://codepen.io/Chokcoco/pen/GRQvqgq

掌握了这个技巧之后,你可以将它运用在非常多只需要简化版的轮播效果之上。

再简单总结一下,非常有意思的技巧:

利用 逐帧动画,实现整体的轮播的循环效果

利用 补间动画,实现具体的 状态A状态B* 的动画效果

逐帧动画 配合 补间动画 构成整体轮播的效果

通过向 HTML 结构末尾补充一组头部数据,实现整体动画的衔接

通过 HTML 元素的 style 标签,利用 CSS 变量,填入实际的参与循环的 DOM 个数,可以实现 JavaScript 与 CSS 的打通

(学习视频分享:web前端)

以上就是原来利用纯CSS也能实现文字轮播与图片轮播!的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1624152.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 08:28:20
下一篇 2025年12月18日 18:23:34

相关推荐

  • 【吐血总结】20+个前端实用工具,快放入收藏夹!

    本篇文章给大家分享20多个前端实用工具,帮助你在开发项目时提升开发效率,快来收藏使用吧,希望对大家有所帮助! 一、CSS布局生成器 Layout:https://layout.bradwoods.io/customize 它是一个全功能的 CSS 和 JSX 生成器,用于使用 CSS Grid 布局…

    2025年12月24日 好文分享
    000
  • 一文了解CSS3中的新属性object-view-box

    本篇文章带大家一起深入了解一下css3中的新特性object-view-box属性,聊聊新属性的作用和使用方法,希望对大家有所帮助! 在开发时,一直希望有一种原生的CSS方式来裁剪图片,并将其定位在我需要的任何方向。这可以通过使用一个额外的HTML元素和不同的CSS属性来实现,后面解释。 在这篇文章…

    2025年12月24日 好文分享
    000
  • CSS变量是怎么工作的?如何使用内联CSS变量进行布局?

    本篇文章带大家了解一下css变量,聊聊css变量是怎么工作的,并介绍一下如何使用内联css变量,以提高灵巧布局效率,希望对大家有所帮助! 有些情况下,我需要用一种简单的方法来创建网格布局。 例如,每次我改变主意时,在不修改CSS的情况下快速画出五列网格。 在本文中,我们一起探索一些用例,并思考如果实…

    2025年12月24日 好文分享
    000
  • 深入探究CSS鼠标指针交互效果

    今天,来实现这样一个有意思的交互效果,通过这个交换效果来聊聊前端鼠标指针交互,希望对大家有所帮助! 将原本的鼠标指针样式,修改成自己想要的效果,并且添加上一些特殊的交互效果。【推荐学习:css视频教程】 修改鼠标样式 首先,第一个问题,我们可以看到,上图中,鼠标指针的样式被修改成了一个圆点: 立即学…

    2025年12月24日 好文分享
    000
  • 纯CSS3怎么实现波浪效果?(代码示例)

    纯css3怎么实现波浪效果?本篇文章就来给大家介绍一下使用 svg 和 css 动画制作波浪效果的方法,希望对大家有所帮助!         随着前端技术的不断发展与进步,界面交互的样式要求和美感也越来越高,很多网页的交互都加上了css3动画,这里作者给大家分享一个前端开发必掌握的一个CSS3波浪效…

    2025年12月24日
    000
  • CSS3动画实战之:超酷炫的粘性气泡效果

    本篇文章带大家聊聊css3动画,看看怎么使用纯 css 实现超酷炫的粘性气泡效果,希望对大家有所帮助! 最近,在 CodePen 上看到这样一个非常有意思的效果: 这个效果的核心难点在于气泡的一种特殊融合效果。【推荐学习:css视频教程】 立即学习“前端免费学习笔记(深入)”; 其源代码在:Code…

    2025年12月24日 好文分享
    000
  • 什么是BFC?深入了解BFC,聊聊作用

    什么是bfc?下面本篇文章带大家了解一下bfc,并聊聊bfc的作用。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 之前在面试字节的时候,面试官问了我有了解BFC吗,我当时其实有看很多文章,但是总是记不住,感觉每个文章讲的都差不多,然后面试时候也没答出来,但是在听了王红元老师讲解的…

    2025年12月24日 好文分享
    000
  • 利用纯CSS如何在滚动时自动添加头部阴影

    利用纯css如何在滚动时自动添加头部阴影?下面本篇文章给大家介绍一下css层级小技巧!看看在滚动时自动添加头部阴影的方法,希望对大家有所帮助! 在网页中,经常会用阴影来突出层级关系,特别是顶部导航,但有时候设计觉得没必要一开始就显示阴影,只有滚动后才出现。比如下面这个例子,注意观察头部阴影。【推荐学…

    2025年12月24日 好文分享
    000
  • 聊聊怎么巧用CSS给普通黑色二维码添上彩色渐变!

    怎么巧用 css 构建渐变彩色二维码?下面本篇文章就来给大家介绍一下利用css给普通黑色二维码添上彩色渐变的方法,希望对大家有所帮助! 今日,群里有个很有意思的问题,问我如何实现一个彩色的,带渐变的二维码,像是这样: 很有意思的问题,我们在百度谷歌,搜索 qrcode,能搜到非常多在线制作二维码的工…

    2025年12月24日 好文分享
    000
  • 聊聊CSS3中的4个逻辑选择器(快速入手)

    本篇文章给大家介绍一下css3中的逻辑选择器,聊聊里面的 4 名成员,希望对大家有所帮助! 在 CSS 选择器家族中,新增这样一类比较新的选择器 — 逻辑选择器,目前共有 4 名成员: :is:where:not:has 本文将带领大家了解、深入它们。做到学以致用,写出更现代化的选择器。…

    2025年12月24日 好文分享
    000
  • 利用CSS也可以处理图片,转为“像素风”!

    如何把图片变成“伪像素风”?本篇文章给大家介绍一下使用css处理图片,将其转为“像素风”的方法,希望对大家有所帮助! 什么是像素风? 像素风是一种以固定大小纯色像素方块作为基本单元,进行创作,包含但不限于绘画、建筑、游戏更各个领域的一种美术风格。其中最让人耳熟能详的,当然是早期电子游戏的像素画面啦~…

    2025年12月24日 好文分享
    000
  • CSS如何进行性能优化?优化小技巧分享

    css如何进行性能优化?下面本篇文章给大家介绍一些css性能优化的小技巧,希望对大家有所帮助! 随着互联网发展至今,对于网站来说,性能显的越来越重要了,CSS作为页面渲染和内容展现的重要环节,影响着用户对整个网站的第一体验。所以,我们需要重视与CSS相关的性能优化。【推荐学习:css视频教程】 项目…

    2025年12月24日
    000
  • 神奇的CSS,实现自动补全字符串!

    本篇文章给大家介绍使用css的实用小技巧,了解一下css自动补全字符串的几种方法,希望对大家有所帮助! 很多时候都会碰到字符串补全的需求,典型的例子就时间或者日期中的补零操作,例如 2021-12-312022-03-03 通常的做法是 if (num < 10) { num = '…

    2025年12月24日 好文分享
    000
  • 聊聊怎么使用CSS滤镜实现内凹平滑圆角效果

    怎么利用css实现内凹平滑圆角效果?下面本篇文章带大家了解一下怎么巧用css滤镜实现内凹平滑圆角效果,希望对大家有所帮助! 某日,群友们在群里抛出这样一个问题,如何使用 CSS 实现如下的布局: 在 CSS 世界中,如果只是下述这种效果,还是非常容易实现的: 立即学习“前端免费学习笔记(深入)”; …

    2025年12月24日 好文分享
    000
  • 一文了解CSS3中的新特性@layer

    本篇文章带大家一起深入了解一下css3中的新特性@layer,希望对大家有所帮助! 步入 2022,CSS 的新特性层出不穷,而最近在 CSS 圈最受瞩目的新特性,非 CSS @layer 莫属。 本文,将用最简洁的语言,快速让读者们搞懂,到底什么是 CSS @layer 新规范。 过往 CSS 优…

    2025年12月24日 好文分享
    000
  • css3包含C语言程序设计吗

    css3不包含C语言程序设计。css3是一种用来表现HTML或XML等文件样式的计算机语言,而C语言程序设计是一种通用的程序设计语言,二者之间不存在包含与被包含的关系。 本教程操作环境:windows10系统、CSS3&&HTML5版、Dell G3电脑。 css3包含C语言程序设计…

    2025年12月24日
    000
  • css3链接怎么设置为没有手的样式

    在css中,可以利用cursor属性设置链接上没有小手的样式,该属性用于定义了鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为default时,鼠标样式为普通箭头样式,语法为“cursor:default;”。 本教程操作环境:windows10系统、CSS3&&HTM…

    2025年12月24日
    000
  • 分享10个纯 CSS 实现的 Loading 效果

    我们遇到加载,要么是ui框架中自带,要么就是百度,然后cv到项目中?但是,自己实现的时候,又会没有思路。下面本篇文章就来给大家分享10个纯 css 实现的 loading 效果,希望对大家有所帮助! 在推特上面看到 T. Afif 介绍的十个 Loading 效果。如上图。 Yeah,很赞哦,挺实用…

    2025年12月24日 好文分享
    000
  • 聊聊使用CSS怎么实现毛玻璃特效(兼容方案探究)

    使用css怎么实现毛玻璃特效?下面本篇文章给大家介绍一下使用css实现毛玻璃特效(兼容方案探究)的方法,希望对大家有所帮助! 前一段时间在某项目中用到了“高斯模糊”的滤镜效果,过程中尝试了多种方案,这里总结一种方式,希望可以帮助到有需要的道友~ UI 小姐姐非要让我在 Android 系统自定义的 …

    2025年12月24日 好文分享
    000
  • 浅析CSS中怎么实现线性渐变(linear-gradient)

    css中怎么实现线性渐变?下面本篇文章给大家介绍一下css线性渐变函数linear-gradient()的使用方法,并聊聊线性渐变的多种应用,希望对大家有所帮助! linear-gradient 1. 语法 linear-gradient([[to |],]? , [, …]?)的使用 二者表现…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信