前端 react 实现图片上传前压缩 缩率图

目录

一、安装

二、编写工具类

三、获取压缩后的File对象


一、安装

复制代码
npm install compressorjs
或
yarn add compressorjs

官方文档:compressorjs - npm (npmjs.com)

二、编写工具类

javascript 复制代码
/**
 * @author Dragon Wu
 * @since 2024/8/4 12:23
 * 图片压缩工具
 */
import Compressor from 'compressorjs';

// 压缩图片方法 (中间件)
export function compressor(file: File, defaultQuality: number = 0.6) {
    console.log('压缩前: ', (file.size / 1024 / 1024).toFixed(1), 'M');//控制台打印图片大小
    const filesize = (file.size / 1024 / 1024).toFixed(1);
    let quality = defaultQuality;
    if (filesize < 0.8) { //这里可以设置自己的压缩规则
        quality = 1;
    } else if (filesize < 1) { 
        quality = 0.8;
    } else if (filesize < 1.5) {
        quality = 0.7;
    } else if (filesize < 2) {
        quality = 0.5;
    } else if (filesize < 3) {
        quality = 0.33;
    } else if (filesize < 4) {
        quality = 0.25;
    } else if (filesize < 5) {
        quality = 0.2;
    } else if (filesize < 8) {
        quality = 0.125;
    } else if (filesize < 10) {
        quality = 0.1;
    } else {
        return new Promise((resolve, reject) => {
            reject({
                msg: '图片不能超过10M'
            })
        });
    }
    console.log('压缩比例: ', quality);

    return new Promise((resolve) => {
        new Compressor(file, {
            quality: quality,
            success(result: File | Blob) {
                console.log('压缩后: ', (result.size / 1024 / 1024).toFixed(1), 'M');
                if (result instanceof Blob) {
                    //@ts-ignore
                    result = new File([result], "f" + (result?.name as string).slice(-8), {type: result.type})
                }
                resolve(result);
            },
            error(err) {
                // 压缩报错的话 返回原图片
                resolve(file);
            },
        });
    });
}

三、获取压缩后的File对象

javascript 复制代码
const handleBeforeUpload = (file: FileType) => {
        const isJpgOrPng = file.type === 'image/jpeg' || file.type === 'image/png';
        if (!isJpgOrPng) {
            message.warning('只能上传JPG/PNG格式!').then();
        }
        const isLt2M = file.size / 1024 / 1024 < 10;
        if (!isLt2M) {
            message.warning('图片不得超过10MB!').then();
        }

        compressor(file).then(res => {
            if (isJpgOrPng && isLt2M) {
                onChange(res)
            }
        })

        return false;
    }

四、测试效果

可以看到源图片已经被压缩了,这样处理后再提交至服务器就能节省带宽,提高前端加载效率了,注意质量数值设置的过小图片过大可能导致图片失帧。

总结到此!

相关推荐
晷龙烬几秒前
Vue组件使用三步走:创建、注册、使用(Vue2/Vue3双版本详解)
前端·javascript·vue.js
前端 贾公子2 分钟前
微信小程序webview访问的url从https变成http原因排查
前端
不爱吃糖的程序媛4 分钟前
React Native for 鸿蒙0.72.5 环境搭建指南
react native·react.js·harmonyos
2501_948122635 分钟前
React Native for OpenHarmony 实战:Steam 资讯 App 设置页面
javascript·react native·react.js·游戏·ecmascript·harmonyos
云和数据.ChenGuang5 分钟前
fastapi无法在微软的edge上运行程序
前端·edge·fastapi
2501_948122636 分钟前
React Native for OpenHarmony 实战:Steam 资讯 App 意见反馈实现
javascript·react native·react.js·游戏·ecmascript·harmonyos
IT_陈寒8 分钟前
Vue3性能优化实战:5个被低估的API让我减少了40%的代码量
前端·人工智能·后端
是罐装可乐9 分钟前
前端架构知识体系:深入理解 sessionStorage、opener 与浏览器会话模型
开发语言·前端·javascript·promise·语法糖
2501_9445210010 分钟前
rn_for_openharmony商城项目app实战-账号安全实现
javascript·数据库·安全·react native·react.js·ecmascript
s19134838482d10 分钟前
web前端-设计表格
前端