码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 神奇的 CSS,让文字智能适配背景颜色


    最近几天,有好几个同学都问了同样一个问题。

    页面上有一段文本,能否实现这段文本在不同背景色下展示不同的颜色?也就是俗称的智能变色。像是下面这样:

    文本在黑色底色上表现为白色,在白色底色上表现为黑色。看似很复杂的一个效果,但是其实在 CSS 中非常好实现,今天就介绍这样一个小技巧,在 CSS 中,利用混合模式 mix-blend-mode: difference,让文字智能适配背景颜色。

    混合模式 mix-blend-mode: difference

    CSS3 新增了一个很有意思的属性 -- mix-blend-mode ,其中 mix 和 blend 的中文意译均为混合,那么这个属性的作用直译过来就是混合混合模式,当然,我们我们通常称之为混合模式。一共有下图所示的一些混合模式:

    其中,本文的主角是 mix-blend-mode: difference,意为差值模式。该混合模式会查看每个通道中的颜色信息,比较底色和绘图色,用较亮的像素点的像素值减去较暗的像素点的像素值。

    与白色混合将使底色反相;与黑色混合则不产生变化。

    通俗一点就是上方图层的亮区将下方图层的颜色进行反相,暗区则将颜色正常显示出来,效果与原图像是完全相反的颜色。

    该混合模式最常见的应用场景就是文章开头描述的场景,实现文本在不同背景色下展示不同的颜色。

    最适合于黑白场景,非常简单的一个 DEMO:

    <div></div>
    
    div {
        height: 100vh;
        background: linear-gradient(45deg, #000 0, #000 50%, #fff 50%);
    
        &::before {
            content: "LOREM IPSUM";
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            color: #fff;
            mix-blend-mode: difference;
            animation: move 3s infinite linear alternate;
        }
    }
    @keyframes move {
        0% {
            transform: translate(-30%, -50%);
        }
        100% {
            transform: translate(-70%, -50%);
        }
    }
    

    效果如下:

    CodePen Demo -- linear-gradient + Mix-blend-mode

    当然,不一定是黑色或者白色,看看下面这个例子,有这样一种场景,有的时候我们不太确定背景颜色的最终表现值(可能是后台配置,传给前端),但是又需要让文字能够在任何背景颜色下都正常展出,此时,也可以尝试使用 mix-blend-mode: difference。

    <ul class="flex-box">
      <div class="box">
        <p>开通会员查看我的VIP等级</p>
      </div>
       // ..... 
    </ul>
    
    div {
        // 不确定的背景色
    }
    p {
        color: #fff;
        mix-blend-mode: difference;
    }
    

    无论背景色是什么颜色,设置了 mix-blend-mode: difference 的 <p> 元素都可以正常展示出文本:

    CodePen Demo -- mix-blend-mode:difference实现文字颜色自适应底色

    mix-blend-mode:difference 的缺点

    当然,这个方法不是完美的,因为通过 mix-blend-mode:difference 与底色叠加之后的颜色,虽然能够正常展示,但是不一定是最适合的颜色,展示效果的最好的颜色。

    这里实际使用的时候,在非黑白场景下,还需要多加实验加以取舍。

    最后

    总结一下,本文介绍了利用 CSS 混合模式实现文本适配背景展示的一个小技巧,如果你对混合模式感兴趣,推荐你再看看我的下列文章:

    • 不可思议的混合模式 mix-blend-mode
    • 不可思议的混合模式 background-blend-mode
    • 两行 CSS 代码实现图片任意颜色赋色技术
    • 巧用 CSS 构建渐变彩色二维码
    • CSS 奇技淫巧 | 妙用混合模式实现文字镂空波浪效果
    • 探究 CSS 混合模式\滤镜导致 CSS 3D 失效问题
    • CSS 艺术 -- 使用 background 创造各种美妙的背景

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

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

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

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

    image

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

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

    微信支付
    支付宝支付
  • 相关阅读:
    风控策略的开发与场景应用
    html+css实现容器显示两行文本超出部分以省略号显示
    Python 笔记01 (变量和面向对象编程)
    设计模式——七大原则详解
    Istio(九):istio安全之授权
    常用的锂电池充电IC芯片
    c语言练习49:有多少⼩于当前数字的数字
    Python: 数据类型转换总结(list-np.array-torch.tensor)
    FFplay文档解读-45-视频过滤器二十
    vue项目分环境配置打包处理
  • 原文地址:https://www.cnblogs.com/coco1s/p/16012545.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号