Home>Article>Web Front-end> How to use CSS background series properties to achieve some fancy text effects
How to use CSS to achieve fancy text effects? The following article will introduce to you how to use the background series attributes to achieve some fancy text effects. I hope it will be helpful to you!
This article will explain how to use thebackground
series of properties to cleverly achieve some fancy text effects. Through this article, you will be able to learn:
background-size
andbackground-position
background-size
andbackground-position
andbackground-clip
to achieve the effect of text gradually appearinganimation- delay
Realize the gradual appearance effect of textThe motivation for writing this article is that one day, I was attracted by such a title--10 Masterfully Designed Websites, which lists 10 extremely creative Web sites.
One of the Red Bull Racing websites is the homepage introducing the F1 Red Bull Racing Team. There is such an interesting hover animation effect:
#The hover effect of this text seems simple, but in fact, if you want to fully realize it, it is very complicated to rely only on CSS. , one of the more difficult parts is -How to make an effect gradually apply to the partof the entire text, instead of giving the entire effect to the entire text at once.
At this point, I remembered the previous article in this article--CSS text decoration text-decoration & text-emphasis, I introduced ausing background to simulate the effect of underline.
Look at a simple DEMO, usebackground
to simulate the underline effect of text:
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; }
Usebackground
to simulate the underline effect of text, the effect is as follows :
backgroundto simulate a dotted underline:
a { background: linear-gradient(90deg, #0cc 50%, transparent 50%, transparent 1px); background-size: 10px 2px; background-repeat: repeat-x; background-position: 100% 100%; }
CodePen Demo -- Use background to simulate underline and dotted underline https://codepen.io/Chokcoco/pen/YzNQKwmOf course this is the most basic, clever use# With various attributes of ##background
, we can achieve various interesting effects.
background-position
realize text hover animation
Here, through clever changes# With the ##background-sizebackground-positionproperties, we can achieve some very interesting text hover effects.
Let’s first look at such a Demo. The core code acts on the
tag:
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; }
Although we set
background: linear-gradient(90deg, #ff3c41, #fc0, #0ebeff)
, but initially defaulted to its
background-size: 0 3px, That is to say, you cannot see the underline at the beginning. When hovering, change
background-size: 100% 3px. At this time, there will be a
0 3pxto
100% 3pxtransformation, which is a stretching effect from scratch.
Look at the final effect:
Because the setbackground-position
is0 100%, if the set
background-positionis
100% 100%, we can get a reverse effect:
// 其他都保持一致,只改变 background-position,从 0 100% 改为 100% 100% a { ... background-position: 100% 100%; ... }
Look at the effect again, you can Compare the above animation to see the specific differences:
##CodePen Demo -- background underline animation
https://codepen.io/Chokcoco/pen/QWdgLwpOK, if we usebackground-positionbackground
to implement two overlapping underlines, then use the above With two different
values, we can get a more interesting underline hover effect. CSS 代码示意,注意看两条使用 background 模拟的下划线的 可以得到这样一种效果,其实每次 hover, 都有两条下划线在移动: CodePen Demo -- background 下划线动画 https://codepen.io/Chokcoco/pen/MWJogjQ 上述一大段都在围绕 --下划线。 回归到本文一开始提到的 Gif 效果,我们能否实现在一段文字中,实现文字的渐现效果呢? 上述技巧利用的是 我们稍微改造下代码,实现利用 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. 看看效果,通过 CodePen Demo -- background-size 与 background-position 以及 background-clip 实现文字逐个渐现 https://codepen.io/Chokcoco/pen/qBjmvdq?editors=1100 当然,稍微对上述代码变形,我们就可以演化出几种不同的效果。 第一种就是从透明到有颜色,逐渐展现,这里我们只需要让 color 一直是 transparent 即可(下述效果借助了一个按钮去触发效果): 效果如下: 还可以实现文字从一种颜色到另外一种颜色的逐个转变,只需要添加多一层 这里需要解释一下,虽然设置了 当 hover 触发时, CodePen -- background-clip 文字渐现效果 https://codepen.io/Chokcoco/pen/XWgpyqz 这里,我们简单利用这个技巧模拟一下文章一开始列出的 Gif 的效果: 这个效果原作者的技巧是: 将每个单词作为一个对象,包裹一个特殊的 class 利用 这里,我们将整段文本统一处理,简单还原: 效果如下: 可以看到,由于是整体控制整段文本,效果上没有逐个单词控制的好,但是优点是代码量非常少。对于一些简单卡片类的 hover 场景,足以。 background-image、background-clip 实现文字渐现效果 https://codepen.io/Chokcoco/pen/abwWMJm 当然,题图效果使用纯 CSS 也是不在话下的。只不过就不是简单能够统一处理的了。 这里,我们需要对每一个单词进行精细化的处理,并且使用每个单词的伪元素进行额外的动画。 简单的结构如下: Lorem ipsum dolor sit amet // ... 类似结构 可以看到,每个单词都被 接下来,就是设定动画,并且通过顺序给每个 其实动画本身不太复杂,主要讲两点: hover 状态下和非 hover 状态下的 借助了 SASS 的循环 最终,我们可以得到如下的结果: 完整的代码,你可以参看 -- CSS 灵感 - 利用 animation-delay 实现文字渐现效果 https://csscoco.com/inspiration/#/./animation/animation-delay-control-text-effect 原文地址:https://segmentfault.com/a/1190000040693286 作者:chokcoco 更多编程相关知识,请访问:编程视频!! The above is the detailed content of How to use CSS background series properties to achieve some fancy text effects. For more information, please follow other related articles on the PHP Chinese website!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; }
通过
background-size
与background-position
配合background-clip
实现文字的渐现background
,那么background
背景色能否改变文字的颜色的?答案是可以的,只需要借助background-clip
。background-clip
实现 hover 的时候部分文字逐渐改变颜色: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
让文字展示出背景色的色值:
实现整段文字的渐现 - 从透明到出现
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%; }
实现整段文字的渐现 - 从一种颜色到另外一种颜色
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)
。linear-gradient(90deg, #999, #999)
这一层渐变逐渐消失,而另外一层 linear-gradient(90deg, #fc0, #fc0)` 逐渐出现,借此实现上述效果。
简单模拟题图效果
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; }
完美还原题图效果
包裹,并且添加了
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; } } }
transition-duration
是不一样的,是因为取消 hover 过程中,动画消失过程的时间通常是要求更短的;@for $i from 1 to 21 {}
递增给每个span
和它的伪元素添加了递增的transition-delay
;