mix-blend-mode 属性

0b47dae23471dd02d84c5c72818ee53a.png

我现在有一个进度条,进度条中间有一串文字,当我的进度条覆盖了文字之后,文字要与进度条反色,怎么实现?

可以使用js的方案,在进度条宽度变化的时候,计算盖过每一个文字的50%,如果超过,设置文字相反颜色。

当然css也有对应的方案,也就是 mix-blend-mode 属性,该属性描述了元素的内容应该与元素的直系父元素的内容和元素的背景如何混合。

mix-blend-mode: normal;
mix-blend-mode: multiply;
mix-blend-mode: screen;
mix-blend-mode: overlay;
mix-blend-mode: darken;
mix-blend-mode: lighten;
mix-blend-mode: color-dodge
mix-blend-mode: color-burn;
mix-blend-mode: hard-light;
mix-blend-mode: soft-light;
mix-blend-mode: difference;
mix-blend-mode: exclusion;
mix-blend-mode: hue;
mix-blend-mode: saturation;
mix-blend-mode: color;
mix-blend-mode: luminosity;


mix-blend-mode: initial;
mix-blend-mode: inherit;
mix-blend-mode: unset;

mix-blend-mode: difference; 在“差值”模式中,查看每个通道中的颜色信息,“差值”模式是将从图像中“基色”颜色的亮度值减去“混合色”颜色的亮度值,如果结果为负,则取正值,产生反相效果。

<head>
  <style>
    .hello {
      color: #fff;
      background: #000;
    }
    .span {
      mix-blend-mode: difference;
    }
</style>
</head>
<body>
  <div class="hello">
    <span class="span">hello</span>
  </div>
</body>

在上面代码中,我们设置的字体颜色是白色和背景颜色是黑色,当把背景颜色改成白色的时候发现字体颜色自动变成黑色的了,产生反相效果。

浏览器兼容性如下:

12e60a68a472adf42d806a3297dff5e0.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值