快捷搜索:

深入理解CSS background-blend-mode的作用机制

深入理解CSSbackground-blend-mode的作用机制

  背景混合模式,最终的效果只会受当前元素的背景图像和背景颜色影响,不会受视觉上处于当前区域其他任意元素影响。

  2.应用background-blend-mode属性后,不仅各个图像之间要进行混合,同时还要和背景色进行混合asp代码加密软件怎么用。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  到此这篇关于深入理解CSS background-blend-mode的作用机制的文章就介绍到这了,更多相关CSS background-blend-mode的作用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

  课程开始: 前三节课,我们知道了什么是“内容块状元素和内联元素”,以及XHTML+CSS布局的核心概念“盒子模型”,同时又学习了一下页面布局中两种方法中的一种方法“浮动&...查看详情

  上节课我们将导航条做成了下面的效果但是此时的导航条还没有链接,还不能点击,这节课我们就要做一个完整的导航条【第四步】 我们需要将上面的导航条做以下几个修改 1)给上面的导航加上链接; 2)链接文字大小修改为12px; 3)并且规定链接样式,鼠标移上去和拿开的效果 修改方法如下 1...查看详情

  【第一步 整体布局与公共CSS定义】我们先来分析一下这个页面页面主要分5大块,顶部的Logo、导航条Nav、Banner、Content、Footer,如下图 下载 (116.12 KB)2009-6-1 09:22这样HTML就很容易写出来了复制代码代码如下: <div ...查看详情

  【第七步 内容左侧板块(ContentL)布局】 我们分析一下他的结构,主要包括标题和文章内容两块,并且标题和内容之间有一条虚线,而第二篇文章的内容部分是图片和文字相结合且文字环绕图片。 好~!既然搞清楚结构了,后面我们布局就容易了 我打算标题用<h1>标签,为什么这...查看详情

  如果下面的文字实在是无法理解透,那就记住这节课最后总结的一句话“如果用position来布局页面,父级元素的position属性必须为relative,而定位于父级内部某个位置的元素,最好用absolute,因为它不受父级元素的padding的属性影响,当然你也可以用...查看详情

  如果你还是不能太明白这句话,我们就做个实例,把我们第5节页面的头部blog区域用定位(position)来布局一下 HTML代码和原来的没有区别: 复制代码代码如下: <div id=Logo> <a href=# id=logoLink>&l...查看详情

  说到浏览器兼容性问题,就必须说CSS Hack!提到Hack大家肯定会想到电脑黑客(hacker)、和病毒程序联系到一块,不过在CSS中,Hack是指一种兼容CSS在不同浏览器中正确显示的技巧方法。说的更直白一些就是,你平时做个页面,布局正确,CSS正确,可就是在不同的浏览器中显...查看详情

  代码如下: HTML代码: 复制代码代码如下: <a id=theLink></a> CSS代码: 复制代码代码如下: #theLink{ display:block;/*因为标签a是内链元素,所以利用这句话将内链元素转化成块状元素,后面的width和...查看详情

  前言为了帮助确保你的网页在所有未来的IE版本都有一致的外观,IE8引入了文件兼容性。在IE6中引入一个增设的兼容性模式,文件兼容性使你能够在IE呈现你的网页时选择特定编译模式。新的IE为了确保网页在未来的版本中都有一支的外观,IE8引入了文件兼容性。当你引入一个增设的兼容性模式,...查看详情

  使用CSS来修饰滚动条 1.overflow内容溢出时的设置 overflow-x水平方向内容溢出时的设置 overflow-y垂直方向内容溢出时的设置 以上三个属性设置的值为visible(默认值)、scroll、hidden、auto。 2.scrollbar-3d-ligh...查看详情

您可能还会对下面的文章感兴趣: