我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript中怎么实现图片压缩功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript中怎么实现图片压缩功能

JavaScript中怎么实现图片压缩功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

压缩思路

涉及到 JS 的图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下:

  •  获取上传 Input 中的图片对象 File

  •  将图片转换成 base64 格式

  •  base64 编码的图片通过 Canvas 转换压缩,这里会用到的 Canvas 的 drawImage 以及 toDataURL 这两个 Api,一个调节图片的分辨率的,一个是调节图片压缩质量并且输出的,后续会有详细介绍

  •  转换后的图片生成对应的新图片,然后输出

优缺点介绍

不过 Canvas 压缩的方式也有着自己的优缺点:

  •  优点:实现简单,参数可以配置化,自定义图片的尺寸,指定区域裁剪等等。

  •  缺点:只有 jpeg 、webp 支持原图尺寸下图片质量的调整来达到压缩图片的效果,其他图片格式,仅能通过调节尺寸来实现

代码实现

<template>    <div class="container">      <input type="file" id="input-img" @change="compress" />      <a :download="fileName" :href="compressImg" >普通下载</a>      <button @click="downloadImg">兼容 IE 下载</button>      <div>        <img :class="lazy" data-src="compressImg" />      </div>    </div>  </template>  <script>  export default {    name: 'compress',    data: function() {      return {        compressImg: null,        fileName: null,      };    },    components: {},    methods: {      compress() {        // 获取文件对象        const fileObj = document.querySelector('#input-img').files[0];        // 获取文件名称,后续下载重命名        this.fileName = `${new Date().getTime()}-${fileObj.name}`;        // 获取文件后缀名        const fileNames = fileObj.name.split('.');        const type = fileNames[fileNames.length-1];        // 压缩图片        this.handleCompressImage(fileObj, type);      },      handleCompressImage(img, type) {        const vm = this;        let reader = new FileReader();        // 读取文件        reader.readAsDataURL(img);        reader.onload = function(e) {          let image = new Image(); //新建一个img标签          image.class="lazy" data-src = e.target.result;          image.onload = function() {            let canvas = document.createElement('canvas');            let context = canvas.getContext('2d');            // 定义 canvas 大小,也就是压缩后下载的图片大小            let imageimageWidth = image.width; //压缩后图片的大小            let imageimageHeight = image.height;            canvas.width = imageWidth;            canvas.height = imageHeight;             // 图片不压缩,全部加载展示            context.drawImage(image, 0, 0);            // 图片按压缩尺寸载入            // let imageWidth = 500; //压缩后图片的大小            // let imageHeight = 200;            // context.drawImage(image, 0, 0, 500, 200);            // 图片去截取指定位置载入            // context.drawImage(image,100, 100, 100, 100, 0, 0, imageWidth, imageHeight);            vm.compressImg = canvas.toDataURL(`image/${type}`);          };        };      },      // base64 图片转 blob 后下载      downloadImg() {        let parts = this.compressImg.split(';base64,');        let contentType = parts[0].split(':')[1];        let raw = window.atob(parts[1]);        let rawrawLength = raw.length;        let uInt8Array = new Uint8Array(rawLength);        for(let i = 0; i < rawLength; ++i) {          uInt8Array[i] = raw.charCodeAt(i);        }        const blob = new Blob([uInt8Array], {type: contentType});        this.compressImg = URL.createObjectURL(blob);        if (window.navigator.msSaveOrOpenBlob) {          // 兼容 ie 的下载方式          window.navigator.msSaveOrOpenBlob(blob, this.fileName);        }else{          const a = document.createElement('a');          a.href = this.compressImg;          a.setAttribute('download', this.fileName);          a.click();        }      },    }  };  </script>

上面的代码是可以直接拿来看效果的,不喜欢用 Vue 的也可以把代码稍微调整一下,下面开始具体分解一下代码的实现思路

Input 上传 File 处理

将 File 对象通过 FileReader 的 readAsDataURL 方法转换为URL格式的字符串(base64 编码)

const fileObj = document.querySelector('#input-img').files[0];  let reader = new FileReader();  // 读取文件  reader.readAsDataURL(fileObj);

Canvas 处理 File 对象

建立一个 Image 对象,一个 canvas 画布,设定自己想要下载的图片尺寸,调用 drawImage 方法在 canvas 中绘制上传的图片

let image = new Image(); //新建一个img标签  image.class="lazy" data-src = e.target.result;  let canvas = document.createElement('canvas');  let context = canvas.getContext('2d');  context.drawImage(image, 0, 0);

Api 解析:drawImage

context.drawImage(img, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);

img

就是图片对象,可以是页面上获取的 DOM 对象,也可以是虚拟 DOM 中的图片对象。

JavaScript中怎么实现图片压缩功能

dx、dy、dWidth、dHeight

表示在 canvas 画布上规划出一片区域用来放置图片,dx, dy 为绘图位置在 Canvas 元素的 X 轴、Y 轴坐标,dWidth, dHeight 指在 Canvas 元素上绘制图像的宽度和高度(如果不说明, 在绘制时图片的宽度和高度不会缩放)。

sx、sy、swidth、sheight

这 4 个参数是用来裁剪源图片的,表示图片在 canvas 画布上显示的大小和位置。sx, sy 表示在源图片上裁剪位置的 X 轴、Y 轴坐标,然后以 swidth, sheight 尺寸来选择一个区域范围,裁剪出来的图片作为最终在 Canvas 上显示的图片内容( swidth, sheight 不说明的情况下,整个矩形(裁剪)从坐标的 sx 和 sy 开始,到图片的右下角结束)。

以下为图片绘制的实例:

context.drawImage(image, 0, 0, 100, 100);  context.drawImage(image, 300, 300, 200, 200);  context.drawImage(image, 0, 100, 150, 150, 300, 0, 150, 150);

JavaScript中怎么实现图片压缩功能

Api 中奇怪之处在于,sx、sy、swidth、sheight 为选填参数,但位置在 dx、dy、dWidth、dHeight 之前。

Canvas 输出图片

调用 canvas 的 toDataURL 方法可以输出 base64 格式的图片。

canvas.toDataURL(`image/${type}`);

Api 解析:toDataURL

canvas.toDataURL(type, encoderOptions);

type 可选

图片格式,默认为 image/png。

encoderOptions 可选

在指定图片格式为 image/jpeg 或 image/webp 的情况下,可以从 0 到 1 的区间内选择图片的质量。如果超出取值范围,将会使用默认值 0.92。其他参数会被忽略。

a 标签的下载

调用 <a> 标签的 download 属性,即可完成图片的下载。

Api 解析:download

// href 下载必填  <a download="filename" href="href"> 下载 </a>

filename

选填,规定作为文件名来使用的文本。

href

文件的下载地址。

非主流浏览器下载处理

到此可以解决 Chroma 、 Firefox 和 Safari(自测支持) 浏览器的下载功能,因为 IE 等浏览器不支持 download 属性,所以需要进行其他方式的下载,也就有了代码中的后续内容

// base64 图片转 blob 后下载  downloadImg() {    let parts = this.compressImg.split(';base64,');    let contentType = parts[0].split(':')[1];    let raw = window.atob(parts[1]);    let rawrawLength = raw.length;    let uInt8Array = new Uint8Array(rawLength);    for(let i = 0; i < rawLength; ++i) {      uInt8Array[i] = raw.charCodeAt(i);    }    const blob = new Blob([uInt8Array], {type: contentType});    this.compressImg = URL.createObjectURL(blob);    if (window.navigator.msSaveOrOpenBlob) {      // 兼容 ie 的下载方式      window.navigator.msSaveOrOpenBlob(blob, this.fileName);    }else{      const a = document.createElement('a');      a.href = this.compressImg;      a.setAttribute('download', this.fileName);      a.click();    }  }
  •  将之前 canvas 生成的 base64 数据拆分后,通过 atob 方法解码

  •  将解码后的数据转换成 Uint8Array 格式的无符号整形数组

  •  转换后的数组来生成一个 Blob 数据对象,通过 URL.createObjectURL(blob) 来生成一个临时的 DOM 对象

  •  之后 IE 类浏览器可以调用 window.navigator.msSaveOrOpenBlob 方法来执行下载,其他浏览器也可以继续通过 <a> 标签的 download 属性来进行下载

Api 解析:atob

base-64 解码使用方法是 atob()。

window.atob(encodedStr)

encodedStr

必需,是一个通过 btoa() 方法编码的字符串,btoa() 是 base64 编码的使用方法。

Api 解析:Uint8Array

new Uint8Array(length)

length

创建初始化为 0 的,包含 length 个元素的无符号整型数组。

Api 解析:Blob

Blob 对象表示一个不可变、原始数据的类文件对象。

// 构造函数允许通过其它对象创建 Blob 对象  new Blob([obj],{type:createType})

obj

字符串内容

createType

要构造的类型

兼容性 IE 10 以上

Api 解析:createObjectURL

静态方法会创建一个 DOMString。

objectURL = URL.createObjectURL(object);

object

用于创建 URL 的 File 对象、Blob 对象或者 MediaSource 对象。

Api 解析:window.navigator

// 官方已不建议使用的文件下载方式,仅针对 ie 且兼容性 10 以上  // msSaveBlob 仅提供下载  // msSaveOrOpenBlob 支持下载和打开  window.navigator.msSaveOrOpenBlob(blob, fileName);

关于JavaScript中怎么实现图片压缩功能问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript中怎么实现图片压缩功能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android中怎么实现图片压缩功能

Android中怎么实现图片压缩功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、图片质量压缩/** * 质量压缩方法 * @param image
2023-05-31

springboot怎么实现图片大小压缩功能

本篇内容主要讲解“springboot怎么实现图片大小压缩功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot怎么实现图片大小压缩功能”吧!application.proper
2023-06-30

Android中怎么实现图片压缩与上传功能

Android中怎么实现图片压缩与上传功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。首先需要对图片进行压缩,这方面可以使用第三方的库,我在实际的开发中使用的
2023-05-30

element前端实现压缩图片的功能

本文主要介绍了element前端实现压缩图片的功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-03-01

java实现上传图片并压缩图片大小功能

Thumbnailator 是一个优秀的图片处理的Google开源Java类库。处理效果远比Java API的好。从API提供现有的图像文件和图像对象的类中简化了处理过程,两三行代码就能够从现有图片生成处理后的图片,且允许微调图片的生成方式
2023-05-31

如何利用canvas实现图片压缩功能

小编给大家分享一下如何利用canvas实现图片压缩功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!项目中做身份证识别时,需要传送图片的 base64 格式编码,
2023-06-09

element前端如何实现压缩图片功能

这篇文章主要讲解了“element前端如何实现压缩图片功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“element前端如何实现压缩图片功能”吧!实现效果如下图所示,从 580kb ->
2023-07-05

如何在 JavaScript 中实现图片放大功能?(JavaScript怎么实现图片放大功能)

在JavaScript中实现图片放大功能是前端开发中常见的需求之一,它可以为用户提供更好的视觉体验,让图片在点击或悬停时以一种平滑且吸引人的方式放大。以下是实现这一功能的详细步骤:一、HTML结构首先,在HTML中创建
如何在 JavaScript 中实现图片放大功能?(JavaScript怎么实现图片放大功能)
JavaScript2024-12-22

JavaScript怎么压缩并加密图片

这篇文章主要介绍了JavaScript怎么压缩并加密图片的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript怎么压缩并加密图片文章都会有所收获,下面我们一起来看看吧。一、压缩图片压缩原理:将图片读
2023-06-29

C#怎么实现无损压缩图片

今天小编给大家分享一下C#怎么实现无损压缩图片的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一般在web应用中,对客户端提交
2023-06-30

python怎么实现图片批量压缩

这篇文章主要介绍python怎么实现图片批量压缩,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!python的数据类型有哪些?python的数据类型:1. 数字类型,包括int(整型)、long(长整型)和float(
2023-06-14

JavaScript图片打印功能怎么实现

这篇文章主要讲解了“JavaScript图片打印功能怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript图片打印功能怎么实现”吧!其实浏览器 window 对象提供了
2023-07-05

编程热搜

目录