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

 更新时间:2024年08月05日 10:43:51   作者:Dragon Wu  
这篇文章主要介绍了前端 react 实现图片上传前压缩(缩率图),本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

一、安装

npm install compressorjs
或
yarn add compressorjs

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

二、编写工具类

/**
 * @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: number = parseFloat((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对象

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;
    }

四、测试效果

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

总结到此!

到此这篇关于前端 react 实现图片上传前压缩 缩率图的文章就介绍到这了,更多相关 react 图片上传前压缩内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • react中事件处理与柯里化的实现

    react中事件处理与柯里化的实现

    本文主要介绍了react中事件处理与柯里化的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • ReactJs设置css样式的方法

    ReactJs设置css样式的方法

    本篇文章主要介绍了ReactJs设置css样式的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 实现React单页应用的方法详解

    实现React单页应用的方法详解

    今天我们来学习React是如何构建起一个单页应用的,React作为目前最流行的前端框架之一,其受欢迎程度不容小觑,从这门框架上我们可以学到许多其他前端框架所缺失的东西,也是其创新性所在的地方,比如虚拟DOM、JSX等。下面一起来看看。
    2016-08-08
  • React实现数字滚动组件numbers-scroll的示例详解

    React实现数字滚动组件numbers-scroll的示例详解

    数字滚动组件,也可以叫数字轮播组件,这个名字一听就是非常普通常见的组件。本文将利用React实现这一组件,感兴趣的小伙伴可以了解一下
    2023-03-03
  • 使用webpack搭建react开发环境的方法

    使用webpack搭建react开发环境的方法

    本篇文章主要介绍了使用webpack搭建react开发环境的方法,在这篇文章中我们开始利用我们之前所学搭建一个简易的React开发环境,用以巩固我们之前学习的Webpack知识。一起跟随小编过来看看吧
    2018-05-05
  • 编写React组件项目实践分析

    编写React组件项目实践分析

    本文通过实例给大家分享了编写React组件项目实践的全过程,对此有兴趣的朋友可以参考下。
    2018-03-03
  • React diff算法超详细讲解

    React diff算法超详细讲解

    渲染真实DOM的开销很大,有时候我们修改了某个数据,直接渲染到真实dom上会引起整个dom树的重绘和重排。我们希望只更新我们修改的那一小块dom,而不是整个dom,diff算法就帮我们实现了这点。diff算法的本质就是:找出两个对象之间的差异,目的是尽可能做到节点复用
    2022-11-11
  • react项目优化配置的操作详解

    react项目优化配置的操作详解

    这篇文章主要介绍了react项目优化配置,主要包括优化配置CDN,优化路由懒加载,结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 深入理解React调度(Scheduler)原理

    深入理解React调度(Scheduler)原理

    本文主要介绍了深入理解React调度(Scheduler)原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • React Native 集成 ArcGIS 地图的详细过程

    React Native 集成 ArcGIS 地图的详细过程

    ArcGIS官方提供了 JavaScript SDK,也提供了 ArcGIS-Runtime-SDK-iOS,但是并没有提供 React Native的版本,所以这里使用了 react-native-arcgis-mapview 库,本文给大家介绍React Native 集成 ArcGIS 地图的详细过程,感兴趣的朋友跟随小编一起看看吧
    2024-06-06

最新评论