广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >HTML5中怎么实现一个图片压缩上传功能
  • 322
分享到

HTML5中怎么实现一个图片压缩上传功能

2024-04-02 19:04:59 322人浏览 八月长安
摘要

这篇文章给大家介绍HTML5中怎么实现一个图片压缩上传功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、创建一个图片和一个canvasXML/html Code复制内容到剪贴板va

这篇文章给大家介绍HTML5中怎么实现一个图片压缩上传功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1、创建一个图片和一个canvas

XML/html Code复制内容到剪贴板

  1. var image = new Image(),   

  2. canvas = document.createElement("canvas"),   

  3. ctx = canvas.getContext('2d');  

2、我们将input中选择的图片地址通过FileReader获取后赋给新建的图片对象,然后将图片对象丢到canvas画布上。

XML/HTML Code复制内容到剪贴板

  1. var file = obj.files[0];   

  2.                         var reader = new FileReader();//读取客户端上的文件   

  3.                         reader.onload = function() {   

  4.                             var url = reader.result;//读取到的文件内容.这个属性只在读取操作完成之后才有效,并且数据的格式取决于读取操作是由哪个方法发起的.所以必须使用reader.onload,   

  5.                             image.src=url;//reader读取的文件内容是base64,利用这个url就能实现上传前预览图片   

  6.                             ...   

  7.                         };   

  8.                         image.onload = function() {   

  9.                             var w = image.naturalWidth,   

  10.                                 h = image.naturalHeight;   

  11.                             canvas.width = w;   

  12.                             canvas.height = h;   

  13.                             ctx.drawImage(image, 0, 0, w, h, 0, 0, w, h);   

  14.                             fileUpload();   

  15.                         };   

  16.                         reader.readAsDataURL(file);  

这里需要注意的是,canvas将图片画到画布上的时候需要确定canvas的尺寸,同时设定好drawImage的参数,具体如下:

XML/HTML Code复制内容到剪贴板

  1. void ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);  

HTML5中怎么实现一个图片压缩上传功能

dx源图像的左上角在目标canvas上 X 轴的位置。

dy源图像的左上角在目标canvas上 Y 轴的位置。

dWidth在目标canvas上绘制图像的宽度。 允许对绘制的图像进行缩放。 如果不说明, 在绘制时图片宽度不会缩放。

dHeight在目标canvas上绘制图像的高度。 允许对绘制的图像进行缩放。 如果不说明, 在绘制时图片高度不会缩放。

sx需要绘制到目标上下文中的,源图像的矩形选择框的左上角 X 坐标。

sy需要绘制到目标上下文中的,源图像的矩形选择框的左上角 Y 坐标。

sWidth需要绘制到目标上下文中的,源图像的矩形选择框的宽度。如果不说明,整个矩形从坐标的sx和sy开始,到图像的右下角结束。

sHeight需要绘制到目标上下文中的,源图像的矩形选择框的高度。

为了上传完整的图片,这里dx,dy必须设置为0,dWidth和dHeight必须设置为原始图片的宽度和高度。这就是为什么我们需要等image对象下载完毕后获取其原始尺寸,这很关键!

3、图片上传

XML/HTML Code复制内容到剪贴板

  1. function fileUpload() {   

  2.      var data = canvas.toDataURL("image/jpeg", quality);   

  3.      //dataURL 的格式为 “data:image/png;base64,****”,逗号之前都是一些说明性的文字,我们只需要逗号之后的就行了   

  4.     datadata = data.split(',')[1];   

  5.     data = window.atob(data);   

  6.     var ia = new Uint8Array(data.length);   

  7.     for (var i = 0; i < data.length; i++) {   

  8.           ia[i] = data.charCodeAt(i);   

  9.     };   

  10.      //canvas.toDataURL 返回的默认格式就是 image/png   

  11.     var blob = new Blob([ia], {   

  12.      type: "image/jpeg"   

  13.     });   

  14.     var fd = new FORMData();   

  15.         fd.append('myFile', blob);   

  16.     var xhr = new XMLHttpRequest();   

  17.     xhr.addEventListener("load", opts.success, false);   

  18.     xhr.addEventListener("error", opts.error, false);   

  19.     xhr.open("POST", opts.url);   

  20.     xhr.send(fd);   

  21.  }  

这里用的关键方法是canvas.toDataURL

XML/HTML Code复制内容到剪贴板

  1. canvas.toDataURL(type, encoderOptions);  

官方的说明是The HTMLCanvasElement.toDataURL() method returns a data URI containing a representation of the image in the format specified by the type parameter (defaults to PNG). The returned image is in a resolution of 96 dpi.实际上就是读取canvas画布上图片的数据。其默认是png格式,如果第一个参数type是image/jpeg的话,第二个参数encoderOptions就可以用来设置图片的压缩质量,经过测试,如果是png格式,100%的宽高经过该方法还有可能使图片变大~~~~适得其反,所以我们可以在canvas.drawImage的时候适当设置sWidth和sHeight,比如同比例缩小1.5倍等,图片质量其实并不太影响查看,尤其对尺寸比较大的图片来说。

上面还有比较陌生的方法atob,其作用是做解码,因为图片格式的base64.

XML/HTML Code复制内容到剪贴板

  1. var encodedData = window.btoa("Hello, world"); // encode a string   

  2. var decodedData = window.atob(encodedData); // decode the string  

该方法解码出来可能是一堆乱码,Uint8Array返回的是8进制整型数组

Blob是存储二进制文件的容器,典型的Blob对象是一个图片或者声音文件,其默认是PNG格式。

XML/HTML Code复制内容到剪贴板

  1. var blob = new Blob([ia], {   

  2.      type: "image/jpeg"   

  3.     });  

最后通过ajax将Blob对象发送到server即可。

整个流程大致如上,但是~~~实现以后测试跑来说:“你不是说图片压缩了吗,为什么图片还是上传那么慢!”,哥拿起手机对妹纸演示了一下,明明很快嘛,于是反道“是你手机不行或者网络不好吧,你下载图片看明明变小了,比之前肯定快,你看我秒传”。呵呵,说归说,还是偷偷检查代码,在浏览器中打时间log,对比没压缩之前的,尼玛!!!居然才快了几百毫秒!!折腾了半天,之前的代码也重构了,玩我呢。

细心的大神看了上面的代码估计能猜出问题在哪,没错,获取本地图片长宽尺寸的时候出了问题。

HTML5中怎么实现一个图片压缩上传功能

我去,获取本地4M大小的图片尺寸花了3174ms!!,图片越大时间也越久~

javascript Code复制内容到剪贴板

  1. image.onload = function() {   

  2.         var w = image.naturalWidth,   

  3.           h = image.naturalHeight;   

  4.         canvas.width = w / 1.5;   

  5.         canvas.height = h / 1.5;   

  6.         ctx.drawImage(image, 0, 0, w, h, 0, 0, w / 1.5, h / 1.5);   

  7.         Upload.fileUpload(type);   

  8. };  

浏览器在本地取图片的时候是没法直接像file.size一样获取其长宽的,只能通过FileReader拿到内容后赋值给新建的image对象,新建的image对象下载需要时间!怎么破?不就是获取本地图片的尺寸吗,难道没有别的办法了?

于是想到了之前研究过的快速获取图片长宽的博文,点击进入 ,demo地址:http://jsbin.com/jivugadure/edit?html,js,output,定时去查询图片加载过程中的高度或者宽度,不用等整个图片加载完毕。

测了下,还是不行,因为定时查询这种方法对常规的server返回的图片有作用,这里图片地址是base64,貌似时间还更久了~哭。


小结一下:

1、用HTML5来压缩图片上传是可行的,在移动端我们不用依赖客户端或者插件,目前主流浏览器支持程度已经很高了。

2、压缩图片一方面是想减少用户上传等待的时间,另外也减少用户为此牺牲的流量,从整体时间来看,因为获取图片尺寸导致多一次下载需要耗时,其实压不压缩时间差别并不是特别大。除非大神们找到合适的方法能够直接获取图片的尺寸,麻烦也告知我一声,万分感谢;

3、既然时间成本差不多,但是我们压缩了图片,减少了图片的大小,减少了流量的消耗,存储空间以及下次获取该图片的时间,所以还是值得的。

 补充源代码:

JavaScript Code复制内容到剪贴板

  1. (function($) {   

  2.     $.extend($.fn, {   

  3.         fileUpload: function(opts) {   

  4.             this.each(function() {   

  5.                 var $self = $(this);   

  6.                 var quality = opts.quality ? opts.quality / 100 : 0.2;   

  7.                 var dom = {   

  8.                     "fileToUpload": $self.find(".fileToUpload"),   

  9.                     "thumb": $self.find(".thumb"),   

  10.                     "progress": $self.find(".upload-progress")   

  11.                 };   

  12.                 var image = new Image(),   

  13.                     canvas = document.createElement("canvas"),   

  14.                     ctx = canvas.getContext('2d');   

  15.                 var funs = {   

  16.                     setImageUrl: function(url) {   

  17.                         image.src = url;   

  18.                     },   

  19.                     bindEvent: function() {   

  20.                         console.log(dom.fileToUpload)   

  21.                         dom.fileToUpload.on("change", function() {   

  22.                             funs.fileSelect(this);   

  23.                         });   

  24.                     },   

  25.                     fileSelect: function(obj) {   

  26.                         var file = obj.files[0];   

  27.                         var reader = new FileReader();   

  28.                         reader.onload = function() {   

  29.                             var url = reader.result;   

  30.                             funs.setImageUrl(url);   

  31.                             dom.thumb.html(image);   

  32.                         };   

  33.                         image.onload = function() {   

  34.                             var w = image.naturalWidth,   

  35.                                 h = image.naturalHeight;   

  36.                             canvas.width = w;   

  37.                             canvas.height = h;   

  38.                             ctx.drawImage(image, 0, 0, w, h, 0, 0, w, h);   

  39.                             funs.fileUpload();   

  40.                         };   

  41.                         reader.readAsDataURL(file);   

  42.                     },   

  43.                     fileUpload: function() {   

  44.                         var data = canvas.toDataURL("image/jpeg", quality);   

  45.                         //dataURL 的格式为 “data:image/png;base64,****”,逗号之前都是一些说明性的文字,我们只需要逗号之后的就行了   

  46.                         data = data.split(',')[1];   

  47.                         data = window.atob(data);   

  48.                         var ia = new Uint8Array(data.length);   

  49.                         for (var i = 0; i < data.length; i++) {   

  50.                             ia[i] = data.charCodeAt(i);   

  51.                         };   

  52.                         //canvas.toDataURL 返回的默认格式就是 image/png   

  53.                         var blob = new Blob([ia], {   

  54.                             type: "image/jpeg"  

  55.                         });   

  56.                         var fd = new FormData();   

  57.                         fd.append('myFile', blob);   

  58.                         var xhr = new XMLHttpRequest();   

  59.                         xhr.addEventListener("load", opts.success, false);   

  60.                         xhr.addEventListener("error", opts.error, false);   

  61.                         xhr.open("POST", opts.url);   

  62.                         xhr.send(fd);   

  63.                     }   

  64.                 };   

  65.                 funs.bindEvent();   

  66.             });   

  67.         }   

  68.     });   

  69. })(Zepto);  

调用方式:

JavaScript Code复制内容到剪贴板

  1. $(".fileUpload").fileUpload({   

  2.                 "url": "savetofile.PHP",   

  3.                 "file": "myFile",   

  4.                 "success":function(evt){   

  5.                     console.log(evt.target.responseText)   

  6.                 }   

  7. });  

关于HTML5中怎么实现一个图片压缩上传功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: HTML5中怎么实现一个图片压缩上传功能

本文链接: https://www.lsjlt.com/news/71777.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • HTML5中怎么实现一个图片压缩上传功能
    这篇文章给大家介绍HTML5中怎么实现一个图片压缩上传功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、创建一个图片和一个canvasXML/HTML Code复制内容到剪贴板va...
    99+
    2022-10-19
  • Android中怎么实现图片压缩与上传功能
    Android中怎么实现图片压缩与上传功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。首先需要对图片进行压缩,这方面可以使用第三方的库,我在实际的开发中使用的...
    99+
    2023-05-30
    android
  • java实现上传图片并压缩图片大小功能
    Thumbnailator 是一个优秀的图片处理的Google开源Java类库。处理效果远比Java API的好。从API提供现有的图像文件和图像对象的类中简化了处理过程,两三行代码就能够从现有图片生成处理后的图片,且允许微调图片的生成方式...
    99+
    2023-05-31
    java 上传图片 压缩图片
  • Nodejs中怎么实现图片上传和压缩预览功能
    这篇文章给大家介绍Nodejs中怎么实现图片上传和压缩预览功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、引入基本配置const Koa = req...
    99+
    2022-10-19
  • H5如何实现图片压缩与上传功能
    这篇文章主要为大家展示了“H5如何实现图片压缩与上传功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“H5如何实现图片压缩与上传功能”这篇文章吧。canvas压...
    99+
    2022-10-19
  • 怎么在HTML5中实现一个图片上传预处理功能
    这篇文章将为大家详细讲解有关怎么在HTML5中实现一个图片上传预处理功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。获取图片通过 File API 获取图片。var input&...
    99+
    2023-06-09
  • spring mvc+localResizeIMG实现HTML5端图片压缩上传
    最近在做一个移动端HTML5的应用,使用到了上传功能,起初使用传统的上传方式上传手机拍照的照片,由于手机拍照出来的照片一般都是好几MB,所以上传速度是非常慢的。在网上找了很久找到了localResizeIMG压缩框架,感觉非常的实用,所以在...
    99+
    2023-05-31
    html5 localresizeimg 上传
  • JavaScript中怎么实现图片压缩功能
    JavaScript中怎么实现图片压缩功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。压缩思路涉及到 JS 的图片压缩,我的想法是需要用...
    99+
    2022-10-19
  • Android中怎么实现图片压缩功能
    Android中怎么实现图片压缩功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、图片质量压缩    public s...
    99+
    2023-05-31
    android
  • 如何使用spring mvc+localResizeIMG实现HTML5端图片压缩上传的功能
    这篇文章主要介绍如何使用spring mvc+localResizeIMG实现HTML5端图片压缩上传的功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!第一步:下载localRes...
    99+
    2022-10-19
  • js如何实现移动端图片压缩上传功能
    这篇文章给大家分享的是有关js如何实现移动端图片压缩上传功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。移动端图片压缩上传功能如何实现?做移动端开发的时候,form里面的fil...
    99+
    2022-10-19
  • 如何使用HTML5移动开发图片压缩上传功能
    这篇文章主要为大家展示了“如何使用HTML5移动开发图片压缩上传功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用HTML5移动开发图片压缩上传功能”这...
    99+
    2022-10-19
  • Android开发中怎么实现一个图片上传功能
    本篇文章给大家分享的是有关Android开发中怎么实现一个图片上传功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。代码实现:private void showDialog()...
    99+
    2023-05-31
    android roi
  • html5中怎么实现图片上传预览功能
    今天就跟大家聊聊有关html5中怎么实现图片上传预览功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。<!DOCTYPE html&...
    99+
    2022-10-19
  • HTML5 和小程序如何实现拍照图片旋转、压缩和上传功能
    这篇文章给大家分享的是有关HTML5 和小程序如何实现拍照图片旋转、压缩和上传功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。最近接到一个“发表评论”的需求:用户输入评论并且可以拍照或从相册选择图片上传,即支持...
    99+
    2023-06-09
  • 怎么用html5的canvas移动浏览器实现图片压缩上传
    这篇文章主要介绍“怎么用html5的canvas移动浏览器实现图片压缩上传”,在日常操作中,相信很多人在怎么用html5的canvas移动浏览器实现图片压缩上传问题上存在疑惑,小编查阅了各式资料,整理出简单...
    99+
    2022-10-19
  • html5中canvas移动浏览器上如何实现图片压缩上传
    这篇文章主要介绍html5中canvas移动浏览器上如何实现图片压缩上传,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、<input type="file"...
    99+
    2022-10-19
  • springboot怎么实现图片大小压缩功能
    本篇内容主要讲解“springboot怎么实现图片大小压缩功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot怎么实现图片大小压缩功能”吧!application.proper...
    99+
    2023-06-30
  • html5实现拖拽上传图片功能
    这篇文章主要讲解了“html5实现拖拽上传图片功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“html5实现拖拽上传图片功能”吧! ...
    99+
    2022-10-19
  • 利用Spring Boot怎么样实现一个图片上传功能
    利用Spring Boot怎么样实现一个图片上传功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体内容如下package com.clou.inteface.domain....
    99+
    2023-05-31
    springboot spring boo
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作