JS实现压缩上传图片base64长度功能
网络编程 2021-07-04 15:02www.168986.cn编程入门
这篇文章主要介绍了js实现压缩上传图片base64长度功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
这篇文章主要介绍了js实现压缩上传图片base64长度功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
im发送图片,现将图片压缩再上传
1) 调用 FileReader 的 reader.readAsDataURL(img); 方法, 在其onload事件中, 将用户选择的图片读入 Image对象.
2) 在image对象的 onload 事件中, 通过 canvas 的 canvas.getContext('2d') 的 drawImage 方法, 将Image 改变大小绘制到canvas上.
3) 通过 canvas.toDataURL("image/jpeg", 1); 方法, 将图片变成base64字符串, 放到send_image_value
toDataURL
canvas.toDataURL(type, encoderOptions);
返回值
包含 data URI 的DOMString
type
图片格式,默认为 image/png
encoderOptions
在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。如果超出取值范围,将会使用默认值 0.92。其他参数会被忽略。
html
<input id="sendImage" title="send a picture" type="file" aept="image/" onchange="imgChange(this)"> <input type="hidden" value="" id="send_image_value"> <img id="showLoadingimg" src="'+CHAT_SITE_URL+'/templates/default/images/loading.gif" style="position:relative;left:200px;:200px;z-index:999;display:none;">
js
function imgChange(e){ //检查是否有文件被选中 if (e.files.length != 0) { var file = e.files[0], fileType = file.type, reader = new FileReader(); if (!reader) { e.value = ''; return; }; var size = file.size; var max_size = 210241024; if(size>max_size){ e.value = ''; $("#send_alert").html('file is too large(>2M)'); return; } $("#showLoadingimg").show(); reader.onload = function(e) { //读取成功,显示到页面并发送到服务器 e.value = ''; var _img = e.target.result; var image_base64 = _img; if(size>102480){//>80K的 var img = new Image(); img.src = _img; img.onload=function(){ var scale = 1; if(this.width > 300 || this.height > 300){ if(this.width > this.height){ scale = 300 / this.width; }else{ scale = 300 / this.height; } } var canvas = document.createElement("canvas"), drawer = canvas.getContext("2d"); if(scale!=1) {//按最大高度等比缩放 img.width = scale; img.height = scale; } canvas.width = img.width; canvas.height = img.width (img.height / img.width); drawer.drawImage(img, 0, 0, canvas.width, canvas.height); var tmp_code = image_base64 = canvas.toDataURL(fileType); if(tmp_code!='data:,'){ image_base64 = tmp_code; } img_send(image_base64); }; }else{ img_send(image_base64); } }; reader.readAsDataURL(file); } } / 为将图片赋值给消息 / function img_send(image_base64){ if(image_base64!='data:,'){ $("#send_image_value").val(image_base64); send_msg(); $("#showLoadingimg").hide(); $('#sendImage').val(""); } }
开始时,toDataURL获取的值是data:,
$("#send_image_value").val(image_base64); send_msg();
这两句写在
reader.onload方法的最狼蚁网站SEO优化这就导致图片并没有压缩
因为img.onload还没执行完
发送的还是原来的图片
在调整后就可以实现图片的压缩了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:Vue实现验证码功能
下一篇:js实现AI五子棋人机大战
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南