自制JPG/PNG在线压缩工具,纯前端实现

一、前......言......对齐

由于自己有强烈的对截图(均是无损,体积很大)处理的强烈诉求,加上市面上并没有满意的工具,因此,一狠心,自己做了个在线压缩工具,相比于tinypng,我这个工具还自带尺寸设置功能,同时还可以控制压缩率,指定压缩格式,纯前端实现,高性能高效率。

二、闪亮登场噔噔噔噔

OK,铺垫了这么久,是时候拉出来瞅瞅了。

您可以狠狠地点击这里:JPG/PNG简易在线尺寸缩放与压缩工具

完整访问地址是:www.zhangxinxu.com/sp/tinyimg/

下图所示的是在桌面端下的布局效果。

中间是操作区,左侧是原图,右侧是压缩后效果预览图。

工具亮点

  • 支持任意图片上传方式,包括直接剪切板粘贴,拖拽上传,以及传统的点击按钮选择文件上传。
  • 支持选择压缩与导出的图片格式(色彩丰富图像选择JPG)。
  • 支持尺寸缩放。
  • 支持批量压缩。
  • 支持移动端。
  • 纯前端实现,速度快,体验好。

三、实现原理说明

JPG前端压缩

JPG的压缩使用的是canvas的toDataURL方法。

css 复制代码
canvas.toDataURL(mimeType, quality);

其中quality就是图像的质量。

但是此方法只适合image/jpeg或者image/webp,所以,PNG的图像压缩无法使用此API。

PNG前端压缩

PNG的前端压缩这里使用的是 UPNG.js,项目地址:github.com/photopea/UP...

还是挺好用的,我用的是下面这个API进行压缩的。

css 复制代码
UPNG.encode(imgs, w, h, cnum, [dels])

其中的cnum就是用来设置PNG压缩损失的,0的话是无损。

其他

其他没什么好说的,上传图片解析,资源下载等,之前都有专门撰文介绍过,我也懒得展开。

总之,技术实现上并不难,就是需要有较多的积累。

四、欢迎使用与反馈

以上就是本工具的基本介绍,欢迎大家使用,终身免费,可以加入收藏,免得日后忘记。

虽然经过多次测试,但个人疏忽在所难免,所以,如果在使用中有什么问题,欢迎反馈。

以及,对于本工具,你还有什么好的想法或者觉得不错的需求,也可以提出来,我会及时跟进进行更新的。

好了,就这些,感谢大家一如既往的支持,比心!

❤️ 🧡 💛 💚 💙 💜

相关推荐
TimelessHaze22 分钟前
拆解字节面试题:async/await 到底是什么?底层实现 + 最佳实践全解析
前端·javascript·trae
执键行天涯1 小时前
从双重检查锁定的设计意图、锁的作用、第一次检查提升性能的原理三个角度,详细拆解单例模式的逻辑
java·前端·github
青青子衿越1 小时前
微信小程序web-view嵌套H5,小程序与H5通信
前端·微信小程序·小程序
OpenTiny社区1 小时前
TinyEngine 2.8版本正式发布:AI能力、区块管理、Docker部署一键强化,迈向智能时代!
前端·vue.js·低代码
qfZYG1 小时前
Trae 编辑器在 Python 环境缺少 Pylance,怎么解决
前端·vue.js·编辑器
bug爱好者1 小时前
Vue3 基于Element Plus 的el-input,封装一个数字输入框组件
前端·javascript
Silence_xl1 小时前
RACSignal实现原理
前端
柯南二号2 小时前
【大前端】实现一个前端埋点SDK,并封装成NPM包
前端·arcgis·npm
dangkei2 小时前
【Wrangler(Cloudflare 的官方 CLI)和 npm/npx 的区别一次讲清】
前端·jvm·npm
乔公子搬砖2 小时前
小程序开发提效:npm支持、Vant Weapp组件库与API Promise化(八)
前端·javascript·微信小程序·js·promise·vagrant·事件绑定