我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CSS中background-blend-mode的作用机制的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CSS中background-blend-mode的作用机制的示例分析

小编给大家分享一下CSS中background-blend-mode的作用机制的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

一、可能都知道的

首先,讲两点大家可能都知道的知识点:

background-blend-mode 本身就带有隔离特性,也就是一个元素应用 background-blend-mode 背景混合模式,最终的效果只会受当前元素的背景图像和背景颜色影响,不会受视觉上处于当前区域其他任意元素影响。

应用 background-blend-mode 属性后,不仅各个图像之间要进行混合,同时还要和背景色进行混合。

接下来,讲下大家可能并不知道的知识点,这也是很多人搞不清楚为什么 background-blend-mode 属性这么渲染的原因。

二、可能不知道的

背景顺序影响混合效果

混合效果和 background 属性中背景图像的顺序密切相关。在CSS多背景中,越是语法中靠后的背景图像的层级越是低,这也是为何 background-color 要写在最后语法才合法的原因,因为背景色的层级永远是最低的。

例如下面2个元素:

<div class="ball"></div><div class="ball2"></div>

设置背景混合模式为叠加,但是两个元素的背景图像的顺序是相反的,代码如下所示:

.ball {    width: 200px; height: 200px;    border-radius: 50%;    background: linear-gradient(deeppink, deeppink), linear-gradient(deepskyblue, deepskyblue);        background-blend-mode: overlay;}.ball2 {    width: 200px; height: 200px;    border-radius: 50%;    background: linear-gradient(deepskyblue, deepskyblue), linear-gradient(deeppink, deeppink);        background-blend-mode: overlay;}

结果下图所示, .ball 元素表现为 deeppink 叠加后面的 deepskyblue ,最终混合颜色偏蓝; .ball2 元素表现为 deepskyblue 叠加后面的 deeppink ,最终混合颜色偏紫。

CSS中background-blend-mode的作用机制的示例分析

混合效果是多个混合属性同时作用的结果

很多开发人员并不清楚, background-blend-mode 支持其实是可以设置多个混合模式值,分别对应不同的背景图像,这一点和仅仅支持一个混合模式值的 mix-blend-mode 属性是不一样的。例如:

.ball {    background: linear-gradient(deeppink, deeppink),         linear-gradient(deepskyblue, deepskyblue);    background-blend-mode: overlay;}

实际上等同于:

.ball {    background: linear-gradient(deeppink, deeppink),         linear-gradient(deepskyblue, deepskyblue);    background-blend-mode: overlay overlay;}

也就是, deeppink 实际上叠加的是deepskyblue和背景色(此例是透明), deepskyblue 叠加的是背景色(此例是透明)。

换言之,实际上,每个背景图像都有一个自己的混合模式值,这是和 mix-blend-mode 属性有着巨大区别的!通常,在使用 mix-blend-mode 属性的场景中,我们只会把混合模式设置在顶层元素上,而不会每一层元素都设置,于是带来了一个由此及彼的严重的思维误区,以为背景混合模式设置的值也是作用在对顶层的背景图像上的,从而导致很多开发者想不通 background-blend-mode 属性的渲染表现和自己预期的不一样。

我们通过一个案例演示下 background-blend-mode 属性的多个值是如何和背景图像一一对应的。

<div class="box"></div>
.box {    width: 200px; height: 200px;    background: linear-gradient(to right bottom, deeppink 50%, transparent 50%),        linear-gradient(to top right, deeppink 50%, transparent 50%),         darkblue;    background-blend-mode: multiply, screen;    position: relative;}.box::before {    content: '';    position: absolute;    width: 33%; height: 33%;    inset: 0;    margin: auto;    background-color: deeppink;}

此时 .box 元素总共呈现出了5种颜色,每种颜色的RGB色值和如何产生的如下图所示。

CSS中background-blend-mode的作用机制的示例分析

其中:

中间标注了序号①的正方形区域没有应用任何混合模式,颜色就是 deeppink ,作用是方便大家和区域③、区域⑤处的颜色进行对比。

  • 区域②就是背景色 darkblue ,因为两个斜向渐变均没有覆盖到这个区域,直接暴露了设置的背景色。

  • 区域③和区域⑤是下层渐变,也就是 background 属性值中位置靠后的渐变,对应的混合模式也是 background-blend-mode 属性值靠后的那个,也就是 screen ,滤色模式,可以让颜色变亮。

  • 区域④和区域⑤是上层渐变,也就是 background 属性值中位置靠前的渐变,对应的混合模式也是 background-blend-mode 属性值靠前的那个,也就是 multiply ,正片叠底模式,可以让颜色变暗。

  • 区域③的颜色表现源自渐变色 deeppink 和背景色 darkblue 进行滤色混合的效果,可以看出最终呈现的颜色比 deeppink 更亮了,最终混合后的色值是 rgb(255,20,206)

  • 区域④的颜色表现源自渐变色 deeppink 和背景色 darkblue 进行正片叠底混合的效果,可以看出最终呈现的颜色比 darkblue 更深了,最终混合后的色值是 rgb(0,0,80)

  • 区域⑤最复杂,理解了这个,也就理解了大多数的 background-blend-mode 属性的渲染表现了。

  • 区域⑤总共有3层,分别是:上层的 deeppink ,混合模式是 multiply ;下层的 deeppink ,混合模式是 screen ;底层的背景色 darkblue

于是,最终的色值表现是上层的 deeppink 使用 multiply 混合下层的 deeppink 和背景色 darkblue 使用 screen 混合后的色值。

由于下层的 deeppink 和背景色 darkblue 使用 screen 混合后的色值就是区域③的颜色。因此,区域⑤的颜色就是 deeppink 和区域③的色值 rgb(255,20,206) 进行正片叠底混合后的色值,结果是 rgb(255,1,119)

以上就是 .box 元素5个颜色各自呈现的原理所在。

三、background-blend-mode与渐变图标的实现

最后再看看看,为何大多数人没办法使用 background-blend-mode 实现渐变图标的效果。

例如,现在有1个颜色很深的删除小图标,理论上,我们可以使用 lighten 混合模式实现渐变效果,因为 lighten 的效果是哪个颜色浅使用哪个颜色,由于图标本身颜色很深,因此,一定会显示渐变色,只要给图标加一个白色底就可以,于是,按照这个思路,很多人就写了如下所示的CSS代码:

.icon-delete {    background: linear-gradient(deepskyblue, deeppink),         url(delete.png), white;    background-blend-mode: lighten;}

乍一看,似乎逻辑上无懈可击,渐变和白底黑色的图标进行变亮混合,怎么想黑色图标也应该变成渐变色啊,很遗憾,最终的渐变并不是渐变色,而是纯白色,为什么会有这样的结果呢?

那是因为这里的 background-blend-mode:lighten 实际上是一个缩写,或者简写,实际上真实的计算值是 lighten lighten ,代码如下所示:

.icon-delete {    background: linear-gradient(deepskyblue, deeppink),         url(delete.png), white;        background-blend-mode: lighten lighten;}

也就是删除图标 delete.png 也应用了混合模式 lighten ,和白色背景色进行了混合,于是变成了纯白色。

知道了问题所在,也就知道了该如何解决了,很简单,让 delete.png 和白色背景色混合后还保持原始图标的模样即可,下面两种CSS方法均可以:

.icon-delete {    background: linear-gradient(deepskyblue, deeppink),         url(delete.png), white;        background-blend-mode: lighten darken;}

或者是:

.icon-delete {    background: linear-gradient(deepskyblue, deeppink),         url(delete.png), white;        background-blend-mode: lighten normal;}

推荐使用 normal 关键字,因为更巧妙,性能也更好一点。最终实现的效果如下图所示。

CSS中background-blend-mode的作用机制的示例分析

当然,渐变图标效果最好的实现方法肯定是 CSS mask 遮罩属性 ,这里的使用混合模式实现的渐变图标会有白色的底,并不是完美的实现方法,主要目的还是让大家了解 background-blend-mode 属性的渲染细节。

四、background-blend-mode的补全规则

background-blend-mode 的属性值的数量和 background-image 不匹配的时候,遵循下面的应用规则:

如果 background-blend-mode 的值的数量大于 background-image ,则多出来的混合模式会被忽略,例如:

.example {     background: linear-gradient(deepskyblue, deeppink), white;    background-blend-mode: lighten, darken;}

等同于:

.example {     background: linear-gradient(deepskyblue, deeppink), white;    background-blend-mode: lighten;}

如果 background-blend-mode 的值的数量少于 background-image ,则会重复完整的 background-blend-mode 属性值进行补全,例如:

.example {     background: linear-gradient(deepskyblue, deeppink),         linear-gradient(deepskyblue, deeppink),        linear-gradient(deepskyblue, deeppink), white;    background-blend-mode: lighten, darken;}

等同于:

.example {     background: linear-gradient(deepskyblue, deeppink),         linear-gradient(deepskyblue, deeppink),        linear-gradient(deepskyblue, deeppink), white;    background-blend-mode: lighten, darken, lighten;}

也就是 lighten, darken 一起进行重复,而不是仅仅重复最后一个混合模式值。因此,补全的值的 lighten

五、结语

CSS background-blend-mode 属性可以让各个背景图像之间应用混合模式。

background-blend-mode 属性的使用频率要明显低于 mix-blend-mode 属性。

原因在于:

真实世界的照片图像很少作为 background-image 背景图像呈现,因为不利于无障碍访问,而混合模式设计的初衷就是这类照片图像的处理;

background-blend-mode 属性作用机制不像 mix-blend-mode 属性那么单纯,很多开发人员并不能很好地驾驭。例如请使用混合模式让透明背景的小图标变成渐变图标,使用 mix-blend-mode 属性实现的人有很多,但是能够使用 background-blend-mode 属性实现的人寥寥无几。

因此,目前 background-blend-mode 属性更常见的应用是用来丰富CSS的背景纹理,例如:

CSS中background-blend-mode的作用机制的示例分析

以上是“CSS中background-blend-mode的作用机制的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CSS中background-blend-mode的作用机制的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

CSS中background-blend-mode的作用机制的示例分析

小编给大家分享一下CSS中background-blend-mode的作用机制的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、可能都知道的首先,讲两点
2023-06-08

jQuery中CSS-DOM操作的示例分析

这篇文章主要为大家展示了“jQuery中CSS-DOM操作的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jQuery中CSS-DOM操作的示例分析”这篇文章吧。除了css()以外,还有
2023-06-29

Linux中make命令工作机制的示例分析

这篇文章主要介绍了Linux中make命令工作机制的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Linux 下 make 命令是系统管理员和程序员用的最频繁的命令之
2023-06-27

Linux中cpufreq机制的示例分析

小编给大家分享一下Linux中cpufreq机制的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!从 2.6.0 Linux 内核开始,您可以通过 CPUf
2023-06-27

java中锁机制的示例分析

这篇文章主要介绍java中锁机制的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!何为同步?JVM规范规定JVM基于进入和退出Monitor对象来实现方法同步和代码块同步,但两者的实现细节不一样。代码块同步是使
2023-06-19

Flex中Hook机制的示例分析

小编给大家分享一下Flex中Hook机制的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!在前一篇简要介绍了基于Flex的界面组合SDK,其中使用Hook机制实现UI Part生命周期管理、Master-Detail
2023-06-17

Ext.js4.2.1中事件机制的示例分析

这篇文章主要为大家展示了“Ext.js4.2.1中事件机制的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Ext.js4.2.1中事件机制的示例分析”这篇文章吧。一: 简介Ext中的事件
2023-06-04

PHP中反射机制的示例分析

小编给大家分享一下PHP中反射机制的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!PHP的反射机制提供了一套反射API,用来访问和使用类、方法、属性、参数
2023-06-15

Python中异常机制的示例分析

小编给大家分享一下Python中异常机制的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、对异常的理解1、什么是异常  异常即“与正常情况不同”,何为正
2023-06-08

CSS中不受控制position fixed的示例分析

小编给大家分享一下CSS中不受控制position fixed的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!失效的 position:fixed在许多情
2023-06-15

python中内存分配机制的示例分析

这篇文章主要介绍了python中内存分配机制的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Python主要用来做什么Python主要应用于:1、Web开发;2、数据
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录