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

[点晴永久免费OA]【JavaScript】JS压缩图片

admin
2023年5月6日 12:40 本文热度 1076

上传图片时候,遇到要上传很大的图片,上传的时候就会很慢。所以,需要对图片进行压缩处理来优化上传功能。

图片压缩函数:

/* 
 * 图片压缩
 * img    原始图片
 * width   压缩后的宽度
 * height  压缩后的高度
 * ratio   压缩比率 
 */
 function compress(img, width, height, ratio) {        
   var canvas, ctx, img64;
        
   canvas = document.createElement('canvas');        
   canvas.width = width;
   canvas.height = height;
        
   ctx = canvas.getContext("2d");        
   ctx.drawImage(img, 0, 0, width, height);
        
   img64 = canvas.toDataURL("image/jpeg", ratio);
        
   return img64;
 }123456789101112131415161718192021

图片压缩函数,返回 base64 格式的图片数据。 其中压缩比率ratio取值(0 - 1 之间),ratio越大图片质量越高。

这里将图片转为 jpeg格式,因为转为 png 格式的话,图片的 base64 比转为 jpeg 的要长不少。

<input type="file" accept="image/*" name="imageFile" @change="upload">1

上传图片后 @change绑定的upload 函数将被触发,在这个函数中获取到图片的资源,将它压缩并利用canvas绘制出来。

  upload () {
   let file = document.queryselector('input[type=file]').files[0] // 获取选择的文件,这里是图片类型
   let reader = new FileReader()
   reader.readAsDataURL(file) //读取文件并将文件以URL的形式保存在resulr属性中 base64格式
   reader.onload = (e) => { // 文件读取完成时触发
    let result = e.target.result // base64格式图片地址
    var image = new Image()
    image.src = result // 设置image的地址为base64的地址
    image.onload = () => { // 图片加载完成后才能进行压缩处理,从而转换为base64 进行赋值
    let width = image.width // 图片宽度
    let height = image.height    let dataUrl = this.compress(image, width, height, 0.7)
    document.getElementById("test").src = dataUrl   }
   }
  }12345678910111213141516

压缩图片结果对比:
大小对比:
在这里插入图片描述
分辨率对比:
在这里插入图片描述
压缩2M的图片:

大小对比:
在这里插入图片描述

分辨率对比:
在这里插入图片描述

demo完整版代码:

<template>
  <div>
  <input type="file" accept="image/*" name="imageFile" @change="upload">
    <img id="test" crossorigin alt="">
 </div></template><script>export default {
 name: '',
 data () {
  return {
  }
 },
 components: {
 },
 created () {
 },
 methods: {
  upload () {
   let file = document.queryselector('input[type=file]').files[0] // 获取选择的文件,这里是图片类型
   let reader = new FileReader()
   reader.readAsDataURL(file) //读取文件并将文件以URL的形式保存在resulr属性中 base64格式
   reader.onload = (e) => { // 文件读取完成时触发
    let result = e.target.result // base64格式图片地址
    var image = new Image()
    image.src = result // 设置image的地址为base64的地址
    image.onload = () => { // 图片加载完成后才能进行压缩处理,从而转换为base64 进行赋值
    let width = image.width // 图片宽度
    let height = image.height    let dataUrl = this.compress(image, width, height, 0.7)
    document.getElementById("test").src = dataUrl   }
   }
  },
  /*
   * 图片压缩
   * img   原始图片
   * width  压缩后的宽度
   * height  压缩后的高度
   * ratio  压缩比率
  */
  compress (img, width, height, ratio) {
   let canvas, ctx, img64;
   canvas = document.createElement('canvas')
   canvas.width = width;
   canvas.height = height;
   ctx = canvas.getContext("2d");
   ctx.drawImage(img, 0, 0, width, height);
   img64 = canvas.toDataURL("image/jpeg", ratio);
   return img64;
  }
 }}</script><style lang="less" scoped></style>

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