前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用 CSS MASK 遮罩优化 PNG 图片

使用 CSS MASK 遮罩优化 PNG 图片

作者头像
2Broear
发布2024-03-12 10:09:43
1410
发布2024-03-12 10:09:43
举报
文章被收录于专栏:2B博客2B博客

使用CSS优化图片

当我们使用工具优化图片到不能再优化时,这时候可以使用CSS的 mask-image 来进行一些操作..

mask-image

正确的使用该属性能优化不少图片体积(不过过程繁琐,一般情况下还是没人用的),mask-image 相当于ps里的遮罩。

实践使用

为了验证该操作的可行性,下面走个流程,首先是原图(尺寸:500x500px 大小:21.8kb)

使用ps将png原图输出为jpg图片(输出较低质量,如50%即可)转为jpg会大幅降低png的大小(jpg大小:15kb)

接着使用ps将原图轮廓填充纯色(较少的色彩会大幅降低png图片的大小)并输出png图片(png大小:2.9kb)

然后在相应图片元素设置 mask-image(-webkit-mask-image) 属性即可看到效果。

代码语言:javascript
复制
img {
      -webkit-mask-image: url(mask.png);
      mask-image: url(mask.png);
  }

遮罩图片的跨域限制

浏览器的跨域安全策略会导致直接引用遮罩图片失败,返回一些错误信息

Access to image at ‘https://img.2broear.com/notes/css-mask-image_200518/mask.png’ from origin ‘https://blog.2broear.com/’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.

跨域解决方案

使用 base64 遮罩图片替代原有url即可(然而3kb的遮罩图转换成base64后还大了2kb..)

代码语言:javascript
复制
img {
      mask-image: url('data:image/png;base64,iVBORw0KGgoAAAA...');
      -webkit-mask-image: url('data:image/png;base64,iVBORw0KGgoAAAA...');
  }

base64在线转换: 文件转 Base64

原图 2kb,转换 base64 后 5kb

最终效果

以上,有问题评论留言反馈。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/06/16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 使用CSS优化图片
    • mask-image
      • 实践使用
        • 遮罩图片的跨域限制
          • 跨域解决方案
            • 最终效果
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档