• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

html - 透明背景在图像调整大小时变为白色

[复制链接]
菜鸟教程小白 发表于 2022-12-11 19:14:23 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我有一个 HTML 页面,我需要在其中渲染 3 个图像,一个在彼此的顶部。

<div id="preview">
    <img src="transparent-image">
</div>

使用以下 CSS

#preview{
    background-image:url(layer0-image), url(layer1-image);
    background-size:100%, 100px;
    background-blend-mode: multiply;
    width: 820px;
    height: 350px;
}

第一个 2 个图像使用 CSS 属性 background-blend-mode: multiply 混合在一起,在此之上,我将最后一张图像(透明图像)与透明背景(想象一张房间的照片,与墙区域是透明的)。

结果正是我想要的,但是当我尝试放入时

#preview{
    width:100%
}

使其响应;它完美无缺,但在 ios 上失去了透明度。 我在 Chrome、Safari 和 Firefox (iOS) 上测试了这种行为。在 OSX、Android、Windows 上的 Chrome、Safari、Firefox 上完全没有问题。

我有什么遗漏吗?感谢您的宝贵时间。

编辑:

layer0-image 和 transparent-image 是同一个图像,layer0-image 没有透明度,并与 layer1-image 相乘,然后在这个混合图像的顶部放置 transparent-image。

我尝试将透明图像更改为另一个,问题似乎是 layer0-image 和 layer1-image 之间的混合,但由于 layer0-image 和 transparent-image 是相同的,起初我认为存在透明度问题。

透明度是存在的,但 div #preview 放置时的高度为 0px

#preview{
    width:100%;
    height:auto;
}

显示没有混合。

EDIT2:

我正在添加一个示例来显示和复制错误:https://jsfiddle.net/dyqnghdo/3/



Best Answer-推荐答案


好的,我终于找到了问题所在。有:

#preview{
    background-image:url(layer0-image), url(layer1-image);
    background-size:100%, 100px;
    background-blend-mode: multiply;
    width: 820px;
    height: 350px;
}

然后设置:

#preview{
    width:100%;
}

导致错误。为了修复它,我尝试设置:

#preview{
    width:100%;
    background-size:cover, 100px;
}

即使我不清楚它为什么会发生,问题也消失了。

关于html - 透明背景在图像调整大小时变为白色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42767279/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap