0

0

js压缩图片的实现原理及实现过程

舞姬之光

舞姬之光

发布时间:2025-11-12 23:45:18

|

440人浏览过

|

来源于php中文网

原创

js压缩图片的核心原理是利用canvas重绘图像,通过缩小尺寸、降低质量、转换格式减小体积。1. 原理:借助canvas的drawimage和toblob实现图像重绘与输出,结合分辨率调整和质量参数控制文件大小,并可将png转jpeg提升压缩率。2. 步骤:先获取file对象,用filereader加载为image,再创建canvas按最大边缩放绘制,最后转为blob或data url。3. 细节:需判断图片类型避免无效压缩,注意exif方向信息丢失问题,手动处理旋转,及时释放临时对象内存,兼容低版本浏览器使用todataurl降级。前端压缩减少上传流量,提升体验,但不能替代服务端校验与处理。

js压缩图片的实现原理及实现过程

JS压缩图片的核心原理是利用Canvas的绘图能力重新绘制图片,并通过调整图片尺寸和设置质量参数来减小文件体积。整个过程不依赖服务器,完全在浏览器端完成,适合前端上传前的预处理。

1. 压缩的基本原理

JavaScript本身不能直接修改图片二进制数据,但可以通过以下方式实现“压缩”:

  • 使用Canvas重绘图像:将图片绘制到canvas元素上,再通过canvas.toDataURL()canvas.toBlob()输出新的、更小的数据。
  • 降低分辨率:缩小图片宽高,减少像素总数,显著降低体积。
  • 控制输出质量:JPEG格式支持设置压缩质量(0-1之间),值越低文件越小,但画质越差。
  • 转换格式:例如将PNG转为JPEG,无损的PNG通常比有损但高压缩率的JPEG大得多。

2. 实现步骤详解

下面是完整的客户端图片压缩流程,适用于用户选择图片后上传前的处理。

步骤一:获取文件对象

通过input[type=file]获取用户选择的图片文件:

const file = document.querySelector('input[type=file]').files[0];

步骤二:创建Image对象加载图片

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

下载

用FileReader读取文件并生成可用的图片源:

const reader = new FileReader();
reader.onload = function(e) {
const img = new Image();
img.src = e.target.result;
img.onload = function() {
// 图片加载完成后进行压缩
compress(img, 800, 0.8);
}
};
reader.readAsDataURL(file);

步骤三:使用Canvas进行压缩

定义compress函数,控制最大边长和质量:

function compress(img, maxWidth, quality) {
let { width, height } = img;
// 按比例缩放,保持最大边不超过maxWidth
if (width > height && width > maxWidth) {
height = Math.round(height * maxWidth / width);
width = maxWidth;
} else if (height > maxWidth) {
width = Math.round(width * maxWidth / height);
height = maxWidth;
}

const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = width;
canvas.height = height;

// 将图片绘制到canvas(自动压缩)
ctx.drawImage(img, 0, 0, width, height);

// 输出Blob对象(推荐用于上传)
return new Promise(resolve => {
canvas.toBlob(resolve, 'image/jpeg', quality);
});
}

步骤四:获取压缩后的文件并上传

compress(img, 800, 0.8).then(blob => {
const compressedFile = new File([blob], 'compressed.jpg', { type: 'image/jpeg' });
// 可以用FormData上传
const formData = new FormData();
formData.append('image', compressedFile);
fetch('/upload', { method: 'POST', body: formData });
});

3. 关键细节说明

实际开发中需要注意以下几点:

  • 图片类型判断:只对JPEG/PNG等大图做压缩,GIF或小图标可跳过。
  • EXIF信息丢失:Canvas压缩会丢掉方向信息(如手机拍摄的旋转),必要时需用库(如exif-js)读取Orientation并手动旋转。
  • 内存释放:临时创建的canvas和img应及时清理,避免内存泄漏。
  • 兼容性:toBlob在老版本IE不支持,可用toDataURL降级处理。

基本上就这些。前端压缩虽不能替代服务端处理,但能有效减少上传流量,提升用户体验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

348

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

185

2025.09.12

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号