您现在的位置是:首页 > 文章详情

JS压缩图片,在线图片压缩,Cavas压缩图片

日期:2019-08-01点击:360

在线DEMOhttps://oktools.net/tinyimg

1. 选择一张图片

 const img_original = document.getElementById('img_original'); const img_output = document.getElementById('img_output'); let blob; function preview(file) { let reader = new FileReader(); reader.onload = function () { img_original.src = this.result; img_original.onload = () => { console.log('图片原始宽高:', img_original.naturalWidth, img_original.naturalHeight); console.log('图片原始大小:', file.size) } }; reader.readAsDataURL(file); } 

2. 使用Canvas压缩

 function compress() { // 压缩到图片原始宽高的一半 let w = img_original.naturalWidth / 2; let h = img_original.naturalHeight / 2; let canvas = document.createElement('canvas'); let ctx = canvas.getContext('2d'); let anw = document.createAttribute("width"); anw.nodeValue = w; let anh = document.createAttribute("height"); anh.nodeValue = h; canvas.setAttributeNode(anw); canvas.setAttributeNode(anh); ctx.fillRect(0, 0, w, h); ctx.drawImage(img_original, 0, 0, w, h); const base64 = canvas.toDataURL('image/jpeg', 0.75);// 压缩后质量 const bytes = window.atob(base64.split(',')[1]); const ab = new ArrayBuffer(bytes.length); const ia = new Uint8Array(ab); for (let i = 0; i < bytes.length; i++) { ia[i] = bytes.charCodeAt(i); } blob = new Blob([ab], {type: 'image/jpeg'}); console.log('压缩后的图片大小', blob.size); // 预览压缩后的图片 img_output.src = base64 } 

3. 保存到本地

 function save() { if (blob) { let a = document.createElement('a'); let event = new MouseEvent('click'); a.download = Math.round(new Date() / 1000) + '.jpg'; a.href = URL.createObjectURL(blob); a.dispatchEvent(event) } } 

在线DEMO https://oktools.net/tinyimg

原文链接:https://yq.aliyun.com/articles/712287
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章