如何利用CSS background系列属性实现一些花式的文字效果

如何利用css实现花式文字效果?下面本篇文章给大家介绍一下利用 background 系列属性实现一些花式文字效果的方法,希望对大家有所帮助!

如何利用CSS background系列属性实现一些花式的文字效果

本文将讲解如何利用 background 系列属性,巧妙的实现一些花式的文字效果。通过本文,你将可以学到:

通过 background-sizebackground-position 实现酷炫的文字下划线效果通过 background-sizebackground-position 以及 background-clip 实现文字逐个渐现的效果通过 animation-delay 实现文字的渐现效果

起因

写本文的动机是在于,某天,被这样一个标题所吸引 — 10 Masterfully Designed Websites,其中列举了 10 个极具创意的 Web 网站。

其中一个 Red Bull Racing 网站,是介绍关于 F1 红牛车队的主页。其中有这样一个非常有意思的 Hover 动画效果:

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

1.gif

这个文字的 hover 出现效果,看似简单,其实想要完全实现它,仅仅依靠 CSS 是非常复杂的,其中一个比较难的地方在于 — 如何让一个效果,逐渐作用给整段文字中的部分,而不是一次将整个效果赋予整段文本。

利用 background 实现文字的下划线效果

到这里,我想起了之前在这篇文章中 — CSS 文字装饰 text-decoration & text-emphasis,我介绍的一种 使用 background 模拟下划线 的效果。

看个简单的 DEMO,使用 background 模拟文字的下划线效果:

Lorem ipsum dolor sit amet consectetur adipisicing elit. Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam, molestiae laboriosam sit repellendus sed sapiente quidem quod accusantium vero.

p {    width: 600px;    font-size: 24px;    color: #666;}a {    background: linear-gradient(90deg, #0cc, #0cc);    background-size: 100% 3px;    background-repeat: no-repeat;    background-position: 100% 100%;    color: #0cc;}

使用 background 模拟文字的下划线效果,效果图如下:

2.png

又或者,使用 background 模拟虚线下划线:

a {    background: linear-gradient(90deg, #0cc 50%, transparent 50%, transparent 1px);    background-size: 10px 2px;    background-repeat: repeat-x;    background-position: 100% 100%;}

3.png

CodePen Demo — 使用 background 模拟下划线与虚线下划线https://codepen.io/Chokcoco/pen/YzNQKwm

当然这个是最基础的,巧妙的运用 background 的各种属性,我们实现各种有意思的效果。

巧妙改变 background-sizebackground-position 实现文字 hover 动效

这里,通过巧妙改变 background-sizebackground-position 属性,我们可以实现一些非常有意思的文字 hover 效果。

先看这样一个 Demo,核心代码作用于被

标签包裹的 标签之上:

Lorem ipsum dolor sit amet consectetur adipisicing elit. Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam, molestiae laboriosam sit repellendus sed sapiente quidem quod accusantium vero.

a {    background: linear-gradient(90deg, #ff3c41, #fc0, #0ebeff);    background-size: 0 3px;    background-repeat: no-repeat;    background-position: 0 100%;    transition: 1s all;    color: #0cc;}a:hover {    background-size: 100% 3px;    color: #000;}

我们虽然,设定了 background: linear-gradient(90deg, #ff3c41, #fc0, #0ebeff),但是一开始默认它的 background-size: 0 3px,也就是一开始是看不到下划线的,当 hover 的时候,改变 background-size: 100% 3px,这个时候,就会有一个 0 3px100% 3px 的变换,也就是一个从无到有的伸展效果。

看看最后的效果:

4.gif

由于设定的 background-position0 100%,如果,设定的 background-position100% 100%,我们可以得到一个反向的效果:

// 其他都保持一致,只改变 background-position,从 0 100% 改为 100% 100%a {    ...    background-position: 100% 100%;    ...}

再看看效果,你可以对比着上面的动图看看具体的差异点在哪:

如何利用CSS background系列属性实现一些花式的文字效果5.gif

CodePen Demo — background 下划线动画

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

OK,如果我们使用 background 实现两条重叠的下划线,再利用上述的两个不同的 background-position 值,我们就可以得到一个更有意思的下划线 hover 效果。

CSS 代码示意,注意看两条使用 background 模拟的下划线的 background-position 的值是不一样的:

a {    background:         linear-gradient(90deg, #0cc, #0cc),        linear-gradient(90deg, #ff3c41, #fc0, #8500d8);    background-size: 100% 3px, 0 3px;    background-repeat: no-repeat;    background-position: 100% 100%, 0 100%;    transition: 0.5s all;    color: #0cc;}a:hover {    background-size: 0 3px, 100% 3px;    color: #000;}

可以得到这样一种效果,其实每次 hover, 都有两条下划线在移动:

6.gif

CodePen Demo — background 下划线动画

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

通过 background-sizebackground-position 配合 background-clip 实现文字的渐现

上述一大段都在围绕 — 下划线

回归到本文一开始提到的 Gif 效果,我们能否实现在一段文字中,实现文字的渐现效果呢?

上述技巧利用的是 background,那么 background 背景色能否改变文字的颜色的?答案是可以的,只需要借助 background-clip

我们稍微改造下代码,实现利用 background-clip 实现 hover 的时候部分文字逐渐改变颜色:

Lorem ipsum dolor sit amet consectetur adipisicing elit. Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam, molestiae laboriosam sit repellendus sed sapiente quidem quod accusantium vero.

p {    color: #666;    cursor: pointer;}a {        background: linear-gradient(90deg, #fc0, #fc0);    background-size: 0 100px;    background-repeat: no-repeat;    background-position: 0 100%;    background-clip: text;    transition: .6s all linear;}p:hover a {    background-size: 100% 100%;    color: transparent;}

看看效果,通过 background-clip: text 的遮罩裁剪,我们将 background: linear-gradient(90deg, #fc0, #fc0) 背景色作用给了文字,同时利用 color: transparent 让文字展示出背景色的色值:

7.gif

CodePen Demo —  background-size 与 background-position 以及 background-clip 实现文字逐个渐现

https://codepen.io/Chokcoco/pen/qBjmvdq?editors=1100

当然,稍微对上述代码变形,我们就可以演化出几种不同的效果。

实现整段文字的渐现 – 从透明到出现

第一种就是从透明到有颜色,逐渐展现,这里我们只需要让 color 一直是 transparent 即可(下述效果借助了一个按钮去触发效果):

a {        background: linear-gradient(90deg, #fc0, #fc0);    background-size: 0 100px;    background-repeat: no-repeat;    background-position: 0 100%;    color: transparent;    background-clip: text;}.button:hover ~ p a {    transition: .8s all linear;    background-size: 0 100px, 100% 100%;}

效果如下:

8.gif

实现整段文字的渐现 – 从一种颜色到另外一种颜色

还可以实现文字从一种颜色到另外一种颜色的逐个转变,只需要添加多一层 background-image 渐变。

a {        background:         linear-gradient(90deg, #999, #999),        linear-gradient(90deg, #fc0, #fc0);    background-size: 100% 100%, 0 100px;    background-repeat: no-repeat;    background-position: 100% 100%, 0 100%;    color: transparent;    background-clip: text;}.button:hover ~ p a {    transition: .8s all linear;    background-size: 0 100px, 100% 100%;}

这里需要解释一下,虽然设置了 color: transparent,但是文字默认还是有颜色的,默认的文字颜色,是由第一层渐变赋予的 background: linear-gradient(90deg, #999, #999), linear-gradient(90deg, #fc0, #fc0),也就是这一层:linear-gradient(90deg, #999, #999)

9.gif

当 hover 触发时,linear-gradient(90deg, #999, #999) 这一层渐变逐渐消失,而另外一层 linear-gradient(90deg, #fc0, #fc0)` 逐渐出现,借此实现上述效果。

CodePen — background-clip 文字渐现效果

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

简单模拟题图效果

这里,我们简单利用这个技巧模拟一下文章一开始列出的 Gif 的效果:

10.gif

这个效果原作者的技巧是:

将每个单词作为一个对象,包裹一个特殊的 class

利用 animation-delay 将动画逐渐赋予每个单词

这里,我们将整段文本统一处理,简单还原:

/** 动画核心 background、line-height、opacity **/a {        background:         linear-gradient(90deg, #ff5722, #ff5722),        linear-gradient(90deg, #aaa, #aaa);    background-size: 100% 100%, 0 100px;    background-repeat: no-repeat;    background-position: 100% 100%, 0 100%;    cursor: pointer;    color: transparent;    background-clip: text;    line-height: 3;    opacity: 0;}.button:hover ~ p a {    transition: 1.2s background .3s ease-out, .8s line-height ease-out, .6s opacity ease-in;    background-size: 0 100px, 100% 100%;    color: transparent;    line-height: 1;    opacity: 1;}/ ** 简单控制半透明黑色遮罩出现 **/a::before {    content: "";    position: fixed;    background: rgba(0, 0, 0, .8);    top: 0;    left: 0;    right: 0;    bottom: 0;    z-index: -1;    transition: .3s all linear;    opacity: 0;}.button:hover ~ p a::before {    opacity: 1;}

效果如下:

11.gif

可以看到,由于是整体控制整段文本,效果上没有逐个单词控制的好,但是优点是代码量非常少。对于一些简单卡片类的 hover 场景,足以。

background-image、background-clip 实现文字渐现效果

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

完美还原题图效果

当然,题图效果使用纯 CSS 也是不在话下的。只不过就不是简单能够统一处理的了。

这里,我们需要对每一个单词进行精细化的处理,并且使用每个单词的伪元素进行额外的动画。

简单的结构如下:

Button

Lorem ipsum dolor sit amet // ... 类似结构

可以看到,每个单词都被 包裹,并且添加了 data-text,方便伪元素拿到当前单词。

接下来,就是设定动画,并且通过顺序给每个 添加相应递增的 animation-delay 以实现没个单词动画的差异性。核心的伪代码如下:

p {    position: relative;    width: 500px;    overflow: hidden;}p span {    position: relative;    display: inline-block;    opacity: 0;    transform: translateY(15px) translateZ(0);    transition-property: transform, opacity;    transition-duration: .3s, .2s;}.button:hover ~ p span {    opacity: 1;    color: #ddd;    transform: translateY(0) translateZ(0);    transition-duration: 1s, .2s;}p span:after,p span:before {    position: absolute;    content: attr(data-text);    top: 0;    left: 0;    z-index: 1;    transform: translateZ(0);}p span:after {    color: #e62541;    transition-property: opacity;    transition-duration: .1s;}.button:hover ~ p span:after {    opacity: 0;    transition-property: opacity;    transition-duration: .4s;}@for $i from 1 to 21 {    p span:nth-child(#{$i}) {        transition-delay: #{$i * 0.04}s;                &::after {            transition-delay: #{$i * 0.04 + 0.2}s;        }    }}

其实动画本身不太复杂,主要讲两点:

hover 状态下和非 hover 状态下的 transition-duration 是不一样的,是因为取消 hover 过程中,动画消失过程的时间通常是要求更短的;

借助了 SASS 的循环 @for $i from 1 to 21 {} 递增给每个 span 和它的伪元素添加了递增的 transition-delay

最终,我们可以得到如下的结果:

12.gif

完整的代码,你可以参看 — CSS 灵感 – 利用 animation-delay 实现文字渐现效果

https://csscoco.com/inspiration/#/./animation/animation-delay-control-text-effect

原文地址:https://segmentfault.com/a/1190000040693286

作者:chokcoco

更多编程相关知识,请访问:编程视频!!

以上就是如何利用CSS background系列属性实现一些花式的文字效果的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 07:36:30
下一篇 2025年12月24日 07:36:46

相关推荐

  • 手把手教你使用纯CSS绘制可爱玉兔(附代码)

    如何使用纯css画一只可爱玉兔?下面本篇文章就手把手教你使用纯css绘制可爱玉兔,希望对大家有所帮助! 这里有段小故事跟大家科普一下哦: 玉兔本是后羿,因为嫦娥奔月,而又思念后羿,后羿为了和嫦娥在一起,情愿变成了她最爱的小动物–玉兔.可惜嫦娥始终不知玉兔就是她日夜思念的后羿! 下面就让我…

    2025年12月24日
    000
  • 深入学习CSS中的 :is() 和 :where(),让样式代码更简洁!

    本篇文章带大家深入了解css中的两个比较高效的选择器,通过它们可以用更少的代码去更有效地选择元素,进而简化代码,下面一起来看看吧! 新人在入门CSS的时候,往往最困惑的就是两件事情(个人想法):1. CSS是基于文档流的,有些时候编写的代码,并不符合自己的预期!2.复杂的选择器,什么场景用什么选择器…

    2025年12月24日 好文分享
    000
  • CSS怎么实现瀑布流?两种方式介绍

    css怎么实现瀑布流?下面本篇文章给大家介绍一下使用css实现瀑布流的两种方式,希望对大家有所帮助! 瀑布流又称瀑布流式布局,是比较流行的一种网站页面布局方式。在手机端进行多图片展示时会经常用到。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次…

    2025年12月24日
    000
  • 给文字添加渐变、描边、投影效果的两种方式(CSS和SVG)

    本篇文章给大家介绍一下使用css和svg给文字添加渐变、描边、投影效果的方法,希望对大家有所帮助! 在一些 web 活动页中经常能看到特殊处理的标题文字,比如这样的 暂时忽略掉特殊字体,通过设计稿的图层样式可以发现,共有 3 个文字特效,分别是渐变、描边、投影 立即学习“前端免费学习笔记(深入)”;…

    2025年12月24日 好文分享
    000
  • 手把手带你通过5个例子来熟悉CSS变量!

    大家对css变量熟悉吗?如果不熟悉,不要紧!下面本篇文章就来给大家介绍一下css变量,通过5个例子来带大家熟悉css变量,希望对大家有所帮助! 随着 Web应用程序变得越来越大,CSS变得越来越大,越来越冗长,而且混乱不堪。 在良好的上下文中使用CSS变量,可为我们提供重用和轻松更改重复出现的CSS…

    2025年12月24日 好文分享
    000
  • 纯CSS做一个烟花绽放动画(代码示例)

    本篇文章带大家使用纯css做一个烟花绽放动画,希望对大家有所帮助! 最近项目上需要做一个烟花动画,要求是随机大小,不同地方出现,先看效果 一、选择合适的动画 什么样的场景决定使用什么样的动画。比如一些比较轻量、装饰性的动画,CSS 动画就足够了,而一些对动画要求比较高的运营活动,创意小游戏等,JS …

    2025年12月24日 好文分享
    000
  • css数字文本过长被隐藏了怎么办

    css数字文本过长被隐藏的解决方法:1、打开相应的HTML文件;2、使用“word-break”属性,给包含数字的元素添加“word-break:break-all;”样式,让数字文本自动换行即可全部显示出来即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、De…

    2025年12月24日 好文分享
    000
  • css怎么去掉表格重复的边框

    在css中,可以使用border-collapse属性来去掉表格中重复的边框,该属性可以设置表格边框是折叠为单一边框还是分开的,只需要将值设置为collapse即可把重叠的边框合并在一起,成为一个边框,实现单线边框的效果。 本教程操作环境:windows7系统、CSS3&&HTML5…

    2025年12月24日
    000
  • 巧用css filter的drop-shadow()函数创建线条光影效果

    本文将介绍一种利用 css 滤镜 filter 的 drop-shadow(),实现对 html 元素及 svg 元素的部分添加阴影效果,以实现一种酷炫的光影效果,用于各种不同的场景之中。 通过本文,你可以学到: 如何利用 filter: drop-shadow() 对元素的部分内容添加单重及多重阴…

    2025年12月24日 好文分享
    000
  • 让网站更酷炫的CSS filter使用小技巧,值得收藏!

    巧用css filter,可以让网站更加酷炫。本篇文章就来给大家分享一些css filter使用小技巧,希望对大家有所帮助! 下面就来开始本篇文章的内容吧! 我们在处理图片时,经常使用的一个功能就是滤镜,它能使一张图像呈现各种不同的视觉效果。 立即学习“前端免费学习笔记(深入)”; 在 CSS 中,…

    2025年12月24日 好文分享
    000
  • 用css怎么画树

    绘制方法:1、定义3个div标签,使用border属性将其修饰成3个大小不同的三角形;2、使用margin属性控制3个三角形的位置,形成树冠;3、定义1个div标签制作树干,使用margin属性将其定位到树冠下方即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、…

    2025年12月24日 好文分享
    000
  • css中如何将行元素转为块元素,块元素转为行元素

    css中可以利用display属性实现行元素和块元素的相互转换:给行元素添加“display:block;”样式可以将其转为块元素;给块元素添加“display:inline;”样式可以将其转为行元素。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电…

    2025年12月24日
    000
  • 怎么设置css文本不可选中

    css文本不可选中的设置方法:1、创建一个HTML示例文件;2、创建div并定义文字内容;3、通过设置“user-select: none;”属性来设置文本不可选中即可。 本文操作环境:windows7系统、HTML5&&CSS3版、Dell G3电脑。 怎么设置css文本不可选中?…

    2025年12月24日
    000
  • css怎么写六边形

    css写六边形的方法:1、把正六边形分成三部分,然后设置before部分,p部分和after部分;2、把正六边形分成三个宽高相同的p,然后使用定位以及css3 transform:rotate分别向左右旋转60deg形成正六边形即可。 本文操作环境:windows7系统、HTML5&&amp…

    2025年12月24日 好文分享
    000
  • css如何让字改变透明度

    css让字改变透明度的方法:1、使用opacity属性,给文字元素添加“opacity:透明度值;”样式即可;2、使用rgba()函数,给文字元素添加“color:rgba(red, green, blue, 透明度值);”样式即可。 本教程操作环境:windows7系统、CSS3&&amp…

    2025年12月24日
    000
  • css隐藏元素的方式有哪些

    方式:1、设置“display:none”语句;2、设置“visibility:hidden”语句;3、设置“opacity:0”语句;4、设置盒模型属性为0;5、利用“position:absolute;top:-9999px;”语句。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日
    000
  • css中如何设置元素宽度

    设置方法:1、使用width属性设置宽度,语法“width:宽度值;”;2、使用min-width属性设置最小宽度,语法“min-width:宽度值;”;3、使用max-width属性设置最大宽度,语法“max-width:宽度值;”。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日 好文分享
    000
  • 手把手教你使用css制作表格边框设置效果(附代码)

    之前的文章《一招教你使用css3制作按钮添加动态效果(代码分享)》中,给大家介绍了怎么使用css3制作按钮添加动态效果。下面本篇文章给大家介绍怎么使用css制作表格边框设置效果,我们一起看看怎么做。 网页中常常有这样的表格布局边框,给大家分享一下看效果图看完效果,我们来研究一下是怎么实现呢,给大家用…

    2025年12月24日 好文分享
    000
  • 详解CSS中的伪元素::before和::after

    本篇文章带大家了解一下css中的::before和::after伪元素,看看它们的应用,希望对大家有所帮助! 本文从最简单的开始,解释如何理解和使用::before和::after。然后再在实际使用场景中去应用它。 ::before和::after是什么? ::before和::after可以添加到…

    2025年12月24日 好文分享
    000
  • 新手篇:如何用css制作图片文字排版(代码分享)

    之前的文章《手把手教你使用css制作表格边框设置效果(附代码)》中,给大家介绍了怎么使用css制作表格边框设置效果。下面本篇文章给大家介绍如何用css制作图片文字排版的方法,我们一起看看怎么做。 网页中常常有这样的CSS图片文字排版,给大家分享一下看效果图看完效果,我们来研究一下是怎么实现呢,给大家…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信