视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
JS+Canvas实现图片预览压缩和上传
2020-11-27 19:56:12 责编:小采
文档
 这次给大家带来JS+Canvas实现图片预览压缩和上传,JS+Canvas实现图片预览压缩和上传的注意事项有哪些,下面就是实战案例,一起来看一下。

先来一张效果图,压压惊

第一步:用户选择需要上传的图片

<input type="file" accept="image/*" type="file"" name="imageFile" onchange="upload()">

在选定了图片后 upload 函数将被触发,我们需要在这个函数中,获取到图片的资源,将它压缩并利用canvas绘制出来,若需要上传到服务器,也可以利用ajax或者其他方式上传。

第二步:获取图片资源压缩预览上传

function upload() { 
 let file = document.querySelector('input[type=file]').files[0] // 获取选择的文件,这里是图片类型 
 let reader = new FileReader() 
 reader.readAsDataURL(file) //读取文件并将文件以URL的形式保存在resulr属性中 base格式 
 reader.onload = function(e) { // 文件读取完成时触发 
 let result = e.target.result // base格式图片地址 
 var image = new Image() image.src = result // 设置image的地址为base的地址 
 image.onload = function(){ 
 var canvas = document.querySelector("#canvas"); 
 var context = canvas.getContext("2d"); 
 canvas.width = image.width; // 设置canvas的画布宽度为图片宽度 
 canvas.height = image.height; 
 context.drawImage(image, 0, 0, image.width, image.height) // 在canvas上绘制图片 
 let dataUrl = canvas.toDataURL('image/jpeg', 0.92) // 0.92为压缩比,可根据需要设置,设置过小会影响图片质量 
 // dataUrl 为压缩后的图片资源,可将其上传到服务器 
 } 
 } 
 }

现在我们来比较一下图片是否成功压缩:

原图大小:

压缩比设置为0.92:

压缩比设置为0.52

乍一看,你是不是觉得很奇怪,为什么设置了缩放比为0.92,图片居然比原图大?其实图片通过base编码后都会变的比原图大,具体原因可以查阅base的编码原理。如此看来,我们已经成功压缩了图片!

注意点:canvas在IE9以下不支持;大图片尽量不要使用base,影响响应速度。

总结

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

postman+json与springmvc如何实现批量添加

Postman怎么进行token传参

jQuery可见性过滤器的用法详解

下载本文
显示全文
专题