当前位置: 首页 > news >正文

javascript压缩图片

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)
        }
    }
复制代码

在线DEMOoktools.net/tinyimg

转载于:https://juejin.im/post/5d40fe8c6fb9a06af92b8015

相关文章:

  • Silver“.NET研究”light 游戏开发小技巧:透明背景的Silverlight程序
  • 在C#中,如何将一个int转换成一个byte array,又如何将一个byte array转换成一个int...
  • SpringBoot2.x集成WebSocket
  • Spinner示例
  • Silverlight杂记-本地程“.NET研究”序间的互通
  • C#.NET支付宝接口
  • 写下我当时的三个愿望
  • 这里有Microsoft Visual Web Developer 2005 Express Edition 软件的下载链接,可创建Web2.0网站的...
  • BizTalk开发系列(十四) XML空白字符(WhiteSpace)
  • MEF——.NET中值“.NET研究”得体验的精妙设计
  • SCUT - 271 - CC 非诚勿扰 - FFT
  • Silverlight 2.5D RPG游戏“.NET研究”技巧与特效处理:(六)流光追影
  • EdoJs之时间显示与转换
  • Eclipse开发Android应用程序入“.NET研究”门:重装上阵
  • 实现局部或全部页面内容不能选中的效果
  • 9月CHINA-PUB-OPENDAY技术沙龙——IPHONE
  • 【编码】-360实习笔试编程题(二)-2016.03.29
  • 【跃迁之路】【699天】程序员高效学习方法论探索系列(实验阶段456-2019.1.19)...
  • Android开源项目规范总结
  • CentOS 7 防火墙操作
  • java8 Stream Pipelines 浅析
  • Java程序员幽默爆笑锦集
  • LeetCode算法系列_0891_子序列宽度之和
  • mac修复ab及siege安装
  • maven工程打包jar以及java jar命令的classpath使用
  • Mysql5.6主从复制
  • python docx文档转html页面
  • Python打包系统简单入门
  • SpiderData 2019年2月13日 DApp数据排行榜
  • Vue.js源码(2):初探List Rendering
  • 闭包--闭包作用之保存(一)
  • 反思总结然后整装待发
  • 基于Dubbo+ZooKeeper的分布式服务的实现
  • 基于HAProxy的高性能缓存服务器nuster
  • 力扣(LeetCode)965
  • 少走弯路,给Java 1~5 年程序员的建议
  • 我与Jetbrains的这些年
  • 详解移动APP与web APP的区别
  • 源码之下无秘密 ── 做最好的 Netty 源码分析教程
  • FaaS 的简单实践
  • 函数计算新功能-----支持C#函数
  • (¥1011)-(一千零一拾一元整)输出
  • (2.2w字)前端单元测试之Jest详解篇
  • (2020)Java后端开发----(面试题和笔试题)
  • (6)STL算法之转换
  • (Repost) Getting Genode with TrustZone on the i.MX
  • (分类)KNN算法- 参数调优
  • (附源码)springboot金融新闻信息服务系统 毕业设计651450
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (十一)手动添加用户和文件的特殊权限
  • (实战篇)如何缓存数据
  • (轉貼) 資訊相關科系畢業的學生,未來會是什麼樣子?(Misc)
  • .htaccess配置常用技巧
  • .net core 3.0 linux,.NET Core 3.0 的新增功能
  • .NET 服务 ServiceController