news 2026/4/23 9:57:01

纯前端图片压缩神器 Compressor.js

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
纯前端图片压缩神器 Compressor.js

点赞 + 关注 + 收藏 = 学会了

本文简介

现在大部分网站都会有图片,不管这个图片是用来展示的,还是需要上传到服务器的。

但图片的体积往往比文字大,会占用更多的服务器空间,也会消耗用户更多的流量。所以在适当范围内压缩一下图片是很有必要的。

今天介绍一款纯前端的图片压缩工具:compressor.js。

虽然这是一款有损的图片压缩工具,但压缩质量还是挺不错的,尤其是它可以在前端运行,对于要上传图片到服务器的业务,可以考虑一下用 compressor.js。

你也可以用 Compressor.js 做个图片压缩的工具网站,用户多了就开个百度或者谷歌的广告,也能赚点奶茶钱。

先体验一下 compressor.js 的效果:https://fengyuanchen.github.io/compressorjs/

这是 compressor.js 的代码仓库:https://github.com/fengyuanchen/compressorjs

动手试试

安装 compressor

npm

npm 通过这条命令安装。

npm install compressorjs

然后在需要使用到 compressor.js 的页面中引入。

importCompressorfrom'compressorjs';

CDN

如果你不使用打包工具,也可以直接通过 CDN 在 HTML 中引入 Compressor.js。

<script src="https://cdn.jsdelivr.net/npm/compressorjs@latest/dist/compressor.min.js"></script>

基础用法

要使用 compressor.js 压缩图片,首先通过new Compressor创建一个压缩实例,并传入文件和一些配置参数。成功后会返回一个压缩后的图片对象。

接下来我用一个小例子演示一下。这个例子通过上传一张图片,然后使用 compressor 压缩它,再返回一个下载链接。

<!-- 文件上传控件 --><inputtype="file"id="fileInput"accept="image/*"><!-- 下载压缩后的图片 --><divid="downloadLink"><aid="downloadCompressed"style="display:none;"download>点击下载压缩后的图片</a></div><!-- 引入 Compressor.js --><scriptsrc="https://cdn.jsdelivr.net/npm/compressorjs@latest/dist/compressor.min.js"></script><script>// 获取 file input 和下载链接元素constfileInput=document.getElementById('fileInput')constdownloadCompressed=document.getElementById('downloadCompressed')// 当文件选择发生变化时触发fileInput.addEventListener('change',function(event){constfile=event.target.files[0]// 获取上传的文件if(!file){return// 如果没有选择文件,则不继续执行}// 使用 Compressor.js 压缩图片newCompressor(file,{success(result){downloadCompressed.href=URL.createObjectURL(result)// 显示下载链接downloadCompressed.style.display='inline'},error(err){console.error('压缩失败:',err)},})})</script>

在这个例子中,使用了<input type="file">作为上传图片的元素,获取到用户上传的图片后,使用new Compressor(file[, options])来压缩图片,new Compressor接收2个参数,第一个参数是图片文件,第二个参数是一系列参数,在本例中的所有参数都使用了默认值。最后通过success()处理压缩成功后的操作,用error()处理压缩失败后的操作。

当压缩成功后就进入success(result)里了,这里的result返回了压缩成功后的图片对象,通过URL.createObjectURL(result)的方式将返回压缩成功后的图片地址。将该地址赋值到<a>标签里就能给用户手动点击下载了。

挺简单吧~

配置压缩强度

在前面的例子中,我们通过new Compressor(file[, options])压缩图片,但压缩的强度默认是 80%,在压缩 JPG 时默认是 92%。如果你希望将图片体积压缩得更小(画质会更差),可以在options这个参数里配置一项qualityquality接收的值是0~1quality的数值越小压缩出来的图片体积就越小,压缩力度就越大。

具体用法:

// 省略部分代码newCompressor(file,{quality:0.6,// 设置压缩质量为 60%success(result){},// 压缩成功后执行这里的代码error(err){}// 压缩失败后执行这里的代码})

设置下载文件的文件名

在前面的例子中,我们下载压缩成功后的图片,文件名看上去是一堆乱码。

比如,我想将压缩后的图片名改成在原图的文件名后面拼上“-德育处主任”,可以这么做。

// 省略部分代码newCompressor(file,{quality:0.6,// 设置压缩质量为 60%success(result){// 获取文件名,并给压缩后的文件加上 "-德育处主任" 后缀constoriginalName=file.name;constextensionIndex=originalName.lastIndexOf('.');constnameWithoutExtension=originalName.substring(0,extensionIndex);constextension=originalName.substring(extensionIndex);downloadCompressed.download=nameWithoutExtension+'-德育处主任'+extension;downloadCompressed.href=URL.createObjectURL(result)// 显示下载链接downloadCompressed.style.display='inline'},error(err){console.error('压缩失败:',err)}})

压缩网络图片

compressor.js 的第一个参数必须是一个File对象(通常是通过文件上传获取的),它不支持直接传入网络图片的 URL。因为它需要操作的是一个本地的FileBlob对象,而不是通过 URL 获取的资源。

但我们可以先通过 JavaScript 将网络图片转换为一个FileBlob对象,然后再将其传递给 compressor.js。

我上传了一张图片到免费的图床上(这是将我公众号的url转成艺术二维码的图片): https://i.imgur.com/zyurGlf_d.webp?maxwidth=760&fidelity=grand

functionurlToBlob(url){returnfetch(url).then((response)=>response.blob()).then((blob)=>{// Step 2: 将 Blob 传递给 Compressor.jsnewCompressor(blob,{quality:0.8,// 设置压缩质量success(result){console.log('压缩后的图片:',result)},error(err){console.error('压缩出错:',err)},})})}constimageUrl='https://i.imgur.com/zyurGlf_d.webp?maxwidth=760&fidelity=grand'urlToBlob(imageUrl)

通过fetch读取这张图片,然后将读取回来的图片执行.blob()方法将其转换成blob再丢给 compressor.js 压缩。

纯前端用 compressor.js 压缩图片,能省服务器空间和流量,还能自定义压缩质量。落地时要考虑工程效率,不妨看看RollCode 低代码平台的私有化部署、自定义组件、静态页面发布(SSG + SEO)能力。


以上就是本文的内容啦,如果你想在线体验一下 compressor.js 的压缩能力,可以试试这个网站 http://worklite.vip/

点赞 + 关注 + 收藏 = 学会了

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 9:01:40

全网最全10个降AIGC网站 千笔帮你轻松降AI率

AI降重工具&#xff1a;让论文更自然&#xff0c;让学术更安心 在当今学术写作中&#xff0c;AI生成内容&#xff08;AIGC&#xff09;已经成为一个不可忽视的现象。许多学生在完成论文时&#xff0c;会借助AI工具进行初步撰写或修改&#xff0c;但随之而来的高AIGC率和查重率…

作者头像 李华
网站建设 2026/4/18 16:40:06

2026年上半年的IT就业市场充满机遇,你准备好了吗?

2026年上半年的IT就业市场充满机遇&#xff0c;你准备好了吗&#xff1f; 随着2026年进入上半年&#xff0c;从AI大模型到网络安全&#xff0c;从芯片设计到云计算运维&#xff0c;各大科技企业纷纷开启 “抢人模式”。小编将为你盘点2026年下半年最热门的IT就业方向&#xff…

作者头像 李华
网站建设 2026/4/18 15:59:27

【小程序毕设源码分享】基于django的咖啡博物馆预约小程序的设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/16 15:42:29

精品PPT | 离散制造行业智能工厂总体解决方案

一、建设背景 离散制造业&#xff0c;包括机械制造业、汽车制造业和家电制造业等&#xff0c;其生产过程涉及多个不连续的工序&#xff0c;产品通常由多个零件装配而成。这类行业面临的挑战包括品种多、批量小、订单变化快、临时插单频繁以及外协件管理困难等问题&#xff0c;…

作者头像 李华
网站建设 2026/4/21 11:25:41

告别报表合并难题!AI Agent 让多源数据整合效率翻倍

在日常工作中&#xff0c;报表合并堪称 “效率杀手”—— 多文件分散存储、跨表关联公式复杂、百万级数据卡顿崩溃、手动操作易出错等问题&#xff0c;让财务、运营、销售等岗位的从业者耗费大量时间却收效甚微。而 Excel-Agent 作为人工智能驱动的数据分析智能体&#xff0c;凭…

作者头像 李华