LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

堪比tinify的图片压缩工具TinyPNG

liguoquan
2024年12月27日 12:44 本文热度 1098
:堪比tinify的图片压缩工具TinyPNG


堪比tinify的图片压缩工具TinyPNG

介绍

  • 基于tinypng的图片压缩工具,支持图片压缩功能。
  • 使用客户端压缩图片,无需上传到服务器,直接在客户端进行压缩。
  • 支持WebWork
  • npm:tinypng-lib
  • 在线体验地址:tinypng.wcrane.cn/

使用方法

  • 安装
shell
代码解读
复制代码
npm install tinypng-lib
  • 基本使用
html
代码解读
复制代码
<template> <div id="app"> <input type="file" @input="uploadImg" /> <img :src="imgUrl" alt=""> </div> </template> <script> import TinyPNG from 'tinypng-lib' export default { name: 'App', components: { }, data() { return { imgUrl: '' } }, methods: { async uploadImg(e) { const file = e.target.files[0]; try { const res = await TinyPNG.compress(file, {}) console.log('res', res) const url = URL.createObjectURL(res.blob) const img = new Image() this.imgUrl = url } catch (error) { console.log("error", error) } } } } </script>

参数说明

参数说明默认值
minimumQuality最小质量35
quality期望压缩质量(0-100)88
fileName压缩后的文件名文件名称
js
代码解读
复制代码
/** * 压缩图片参数 */ interface CompressOptions { minimumQuality?: number; // 最小质量 quality?: number; // 压缩质量 0 - 100 fileName?: string; // 压缩后的文件名, 默认为file.name }

返回值说明

js
代码解读
复制代码
/** * 压缩图片结果 */ interface CompressResult { success: boolean, // 是否成功 file: File, // 压缩后的文件 originalSize: number, // 原始文件大小 compressedSize: number, // 压缩后文件大小 rate: number, // 压缩率(压缩为原来的%) output: ArrayBuffer, // 压缩后的 ArrayBuffer blob: Blob, // 压缩后的 Blob rateString: string, // 压缩率字符串 }

WebWorker中使用

基本使用

  1. webpack项目中安装worker-loader
shell
代码解读
复制代码
npm install worker-loader
  1. webpack.config.js中配置
js
代码解读
复制代码
module.exports = { // ... module: { rules: [ { test: /.worker.js$/, use: { loader: 'worker-loader' }, }, ], }, };
  1. 定义imageWorker.worker.js
js
代码解读
复制代码
// imageWorker.worker.js import TinyPNG from 'tinypng-lib'; self.onmessage = async function (e) { const { image, options } = e.data; try { // 使用支持webWorker的方法 const result = await TinyPNG.compressWorkerImage(image, options); self.postMessage(result); } catch (error) { self.postMessage({ error: error.message }); } };
  1. 在组件中使用
  • 监听webworker的消息
  • 使用 TinyPNG.getImage 处理文件信息
  • 发送图片信息给webworker进行压缩
  • 接收webworker返回的压缩结果
js
代码解读
复制代码
<script> // Import the worker import ImageWorker from './imageWorker.worker.js'; // This is the bundled worker import { getSizeTrans } from '../utils'; import TinyPNG from 'tinypng-lib'; export default { name: 'Base', mounted() { // Start the worker when the component is mounted this.worker = new ImageWorker(); // Receive the message (compressed result) from the worker this.worker.onmessage = (e) => { this.compressing = false; const result = e.data; if (result.error) { console.error("Compression failed:", result.error); } else { // 拿到压缩结果 console.log(e); } }; }, methods: { getSizeTrans, async uploadImg(e) { const file = e.file; // 获取图片信息 const image = await TinyPNG.getImage(file); // Send the file to the worker for compression this.worker.postMessage({ image, options: { minimumQuality: 30, quality: 85 } }); } }, beforeDestroy() { // Terminate the worker when the component is destroyed if (this.worker) { this.worker.terminate(); } } } </script>
  1. 说明:对于jpeg、jpg的图片不支持使用WebWorker压缩需要使用TinyPNG.compressJpegImage 进行压缩
js
代码解读
复制代码
import TinyPNG from 'tinypng-lib'; TinyPNG.compressJpegImage(file, options)

CompressWorker 使用

  • 封装代码
js
代码解读
复制代码
import ImageWorker from './imageWorker.worker.js'; // 与前面imageWorker.worker.js一致 export class CompressWorker { worker = null; constructor() { this.worker = new ImageWorker(); } async compress(file, options) { // 获取图片信息 const image = await TinyPNG.getImage(file); return new Promise((resolve, reject) => { // 监听worker的消息 this.worker.onmessage = (e) => { const result = e.data; if (result.error && !result.success) { console.error("Compression failed:", result.error); reject(result.error); } else { resolve(result); } }; // Send the file to the worker for compression this.worker.postMessage({ image, options }); }); } terminate() { if (this.worker) { this.worker.terminate(); this.worker = null; } } }
  • 使用

    • 实例化:CompressWorker只注册一次就行,比如vue的mounted生命周期
    • 图片压缩
    • 页面或者组件卸载的时候执行, 销毁 CompressWorker 实例
js
代码解读
复制代码
// 1. 只注册一次就行,比如vue的mounted生命周期 compressWorker = new CompressWorker(); // 2. 监听选择的图片,图片压缩 compressWorker.compress(file, { minimumQuality: 30, quality: 85 }).then((result) => { // 压缩结果 console.log(result); }) // 3. 页面或者组件卸载的时候执行, 销毁webworker if (compressWorker) { compressWorker.terminate(); }

注意事项

  • 请确保已经安装了tinypng-lib模块

该文章在 2024/12/27 12:44:55 编辑过
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved