码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 多行文本下的文字渐隐消失术


    本文将探讨一下,在多行文本情形下的一些有意思的文字动效。

    多行文本,相对于单行文本,场景会复杂一些,但是在实际业务中,多行文本也是非常之多的,但是其效果处理比起单行文本会更困难。

    单行与多行文本的渐隐

    首先,我们来看这样一个例子,我们要实现这样一个单行文本的渐隐:

    使用 mask,可以轻松实现这样的效果,只需要:

    <p>Lorem ipsum dolor sit amet consectetur.p>
    
    p {
        mask: linear-gradient(90deg, #fff, transparent);
    }
    

    但是,如果,场景变成了多行呢?我们需要将多行文本最后一行,实现渐隐消失,并且适配不同的多行场景:

    这个就会稍微复杂一点点,但是也是有多种方式可以实现的。

    首先我们来看一下使用 background 的方式。

    使用 background 实现

    这里会运用到一个技巧,就是 display: inline 内联元素的 background 展现形式与 display: block 块级元素(或者 inline-block、flex、grid)不一致。

    简单看个例子:

    <p>Lorem .....p>
    <a>Lorem .....a>
    

    这里需要注意,

    元素是块级元素,而 是内联元素。

    我们给它们统一添加上一个从绿色到蓝色的渐变背景色:

    p, a {
      background: linear-gradient(90deg, blue, green);
    }
    

    看看效果:

    什么意思呢?区别很明显,块级元素的背景整体是一个渐变整体,而内联元素的每一行都是会有不一样的效果,整体连起来串联成一个整体。

    基于这个特性,我们可以构造这样一种布局:

    <p><a>Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quama>p>
    
    p {
        position: relative;
        width: 400px;
    }
    
    a {
        background: linear-gradient(90deg, transparent, transparent 70%, #fff);
        background-repeat: no-repeat;
        cursor: pointer;
        color: transparent;
        
        &::before {
            content: "Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam";
            position: absolute;
            top: 0;
            left: 0;
            color: #000;
            z-index: -1;
        }
    }
    

    这里需要解释一下:

    1. 为了利用到实际的内联元素的 background 的特性,我们需要将实际的文本包裹在内联元素 内
    2. 实际的文本,利用了 opacity: 0 进行隐藏,实际展示的文本使用了 元素的伪元素,并且将它的层级设置为 -1,目的是让父元素的背景可以盖过它
    3. 元素的渐变为从透明到白色,利用它去遮住下面的实际用伪元素展示的文字,实现文字的渐隐

    这样,我们就能得到这样一种效果:

    这里, 元素的渐变为从透明到白色,利用后面的白色逐渐遮住文字。

    如果我将渐变改为从黑色到白色(为了方便理解,渐变的黑色和白色都带上了一些透明),你能很快的明白这是怎么回事:

    a {
        background: linear-gradient(90deg, rgba(0,0,0, .8), rgba(0,0,0, .9) 70%, rgba(255, 255, 255, .9));
    }
    

    完整的代码,你可以戳这里:CodePen Demo -- Text fades away

    当然,这个方案有很多问题,譬如利用了 z-index: -1,如果父容器设置了背景色,则会失效,同时不容易准确定位最后一行。因此,更好的方式是使用 mask 来解决。

    使用 mask 实现

    那么,如果使用 mask 的话,问题,就会变得简单一些,我们只需要在一个 mask 中,实现两块 mask 区域,一块用于准确控制最后一行,一块用于控制剩余部分的透明。

    也不需要特殊构造 HTML:

    <p>Lorem ipsum dolor sit amet ....p>
    
    p {
        width: 300px;
        padding: 10px;
        line-height: 36px;
        mask: 
            linear-gradient(270deg, transparent, transparent 30%, #000),
            linear-gradient(270deg, #000, #000);
        mask-size: 100% 46px, 100% calc(100% - 46px);
        mask-position: bottom, top;
        mask-repeat: no-repeat;
    }
    

    效果如下:

    核心在于整个 mask 相关的代码,正如上面而言的,mask 将整个区域分成了两块进行控制:

    在下部分这块,我们利用 mask 做了从右向左的渐隐效果。并且利用了 mask-position 定位,以及 calc 的计算,无论文本都多少行,都是适用的!需要说明的是,这里的 46px 的意思是单行文本的行高加上 padding-bottom 的距离。可以适配任意行数的文本:

    完整的代码,你可以戳这里:CodePen Demo -- Text fades away 2

    添加动画效果

    好,看完静态的,我们再来实现一种**动态的文字渐隐消失。

    整体的效果是当鼠标 Hover 到文字的时候,整个文本逐行逐渐消失。像是这样:

    这里的核心在于,需要去适配不同的行数,不同的宽度,而且文字是一行一行的进行消失。

    这里核心还是会运用上内联元素 background 的特性。在 妙用 background 实现花式文字效果 这篇文章中,我们介绍了这样一种技巧。

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

    <div class="button">Buttondiv>
    <p><a>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>p>
    
    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)。

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

    CodePen -- background-clip 文字渐现效果

    好,我们可以借鉴这个技巧,去实现文字的渐隐消失。一层为实际的文本,而另外一层是进行动画的遮罩,进行动画的这一层,本身的文字设置为 color: transparent,这样,我们就只能看到背景颜色的变化。

    大致的代码如下:

    <p>
        <a class="word">Mollitia nostrum placeat consequatur deserunt.a>
        <a class="pesudo">Mollitia nostrum placeat consequatur deserunt.a>
    p>
    
    p {
        width: 500px;
    }
    .word {
        position: absolute;
        top: 0;
        left: 0;
        color: transparent;
        color: #000;
    }
    .pesudo {    
        position: relative;
        background: linear-gradient(90deg, transparent, #fff 20%, #fff);
        background-size: 0 100%;
        background-repeat: no-repeat;
        background-position: 100% 100%;
        transition: all 3s linear;
        color: transparent;
    }
    p:hover .pesudo,
    p:active .pesudo{
        background-size: 500% 100%;
    }
    

    其中,.word 为实际在底部,展示的文字层,而 pesudo 为叠在上方的背景层,hover 的时候,触发上方元素的背景变化,逐渐遮挡住下方的文字,并且,能适用于不同长度的文本。

    当然,上述方案会有一点瑕疵,我们无法让不同长度的文本整体的动画时间一致。当文案数量相差不大时,整体可以接受,文案相差数量较大时,需要分别设定下 transition-duration 的时长。

    完整的 DEMO,你可以戳:CodePen -- Text fades away Animation

    最后

    好了,本文到此结束,希望对你有帮助 😃

    更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。

    如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

    想 Get 到最有意思的 CSS 资讯,千万不要错过我的 iCSS 公众号 😄 :

    image

    如果觉得文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
    打赏支持
    +

    (^_^)打个赏喝个咖啡(^_^)

    微信支付
    支付宝支付
  • 相关阅读:
    Amine-PEG3-carboxylic acid, hydrochloride;氨基三聚乙二醇羧基,盐酸盐,127457-79-8
    Java抽象工厂模式之总有你想不到的知识
    hive on spark问题记录
    【C++之数组与指针】随机输入整数存入数组并用指针遍历
    Web服务器配置管理
    react高频面试题总结(附答案)
    从零搭建开发脚手架 自定义HandlerMethodArgumentResolver-注解@JsonArg和实体CurrentUser
    彻底改变日常生活:面向消费类应用的物联网
    Maven的安装和环境变量配置
    快递地址自动识别填充
  • 原文地址:https://www.cnblogs.com/coco1s/p/16590809.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号