CSS 背景图片和背景颜色融合,以及多张背景图片融合显示


写CSS的时候会遇到这样一个需求,要求给背景图片加上一个“遮罩层”,看起来更符合页面的整体风格。

可以用背景图片和背景颜色融合来解决。

通常我们这样写:

          .bgDiv {

                       background:rgba(255, 0, 0, 0.1), url(...);

           }

这样的写法的问题是,只有在图片覆盖不到的区域才能看到背景颜色,或者png图片的透明部分,才能看到。

这样达不到我们的要求,就需要另外的方法解决了,添加background的一个属性,background-blend-mode:multiply;

background-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;           复原

/* One value */
background-blend-mode: normal;

/* Two values, one per background */
background-blend-mode: darken, luminosity;

/* Global values */
background-blend-mode: initial;
background-blend-mode: inherit;
background-blend-mode: unset;

参考档案:https://developer.mozilla.org/en-US/docs/Web/CSS/background-blend-mode

除了这个还有另外一个方法,利用css背景渐变:

.bgDiv {

                       background:linear-gradient(bottom, rgba(255, 0, 0, 0.1), rgba(255, 0, 0, 0.1)), url(...);

           }


很奇怪,但是有用。


当然还有方法就是用PS先把图片做好了直接给前端使用,方法是新建图层,填充颜色,然后设置不透明度。





  • 4
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在六边形中添加图片为背景,可以使用CSS的background属性。以下是一个示例代码: ```html <div class="hexagon"> <div class="hexagon-inner"></div> </div> ``` ```css .hexagon { width: 200px; height: 115px; position: relative; margin: 57.5px 0; } .hexagon:before, .hexagon:after { content: ""; position: absolute; width: 0; border-left: 100px solid transparent; border-right: 100px solid transparent; } .hexagon:before { bottom: 100%; border-bottom: 57.5px solid #ccc; } .hexagon:after { top: 100%; width: 0; border-top: 57.5px solid #ccc; } .hexagon-inner { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url('your-image-url-here'); background-size: cover; background-position: center; opacity: 0.8; } ``` 在这个示例中,我们添加了一个内部div元素来放置背景图片。我们将其设置为绝对定位,并将其放置在六边形的顶部左侧。我们还设置了其宽度和高度为100%,使其覆盖整个六边形。 接下来,我们使用CSS的background-image属性来设置背景图片的URL。我们还使用background-size和background-position属性来调整背景图片的大小和位置。我们还使用opacity属性将透明度设置为0.8,以使背景图片稍微暗淡一些,以便更好地与文本内容区分开来。 最后,我们在六边形的:before和:after伪元素中添加了一些基本的CSS样式,以使其看起来像一个六边形。请注意,我们将六边形的颜色设置为#ccc,以使其与背景图片更好地融合

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值