文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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

压缩思路

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

优缺点介绍

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

代码实现

<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 :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.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.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();    }  }

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯