js 压缩图片

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
var f = data[0];  //图片地址
var xhr = new XMLHttpRequest()
xhr.open('GET', f, true)
xhr.responseType = 'blob'
xhr.onload = function() {
    console.log("到此了");
    console.log(this.response.size);
    if(this.response.size>250000){
        let img = new Image(); 
        img.src = f; // 要压缩的图片
        let width=0;
        let height=0;
        img.onload=function(){ 
            width = img.width; 
            height = img.height; 
          
            let canvas = document.createElement('canvas');
            let ctx = canvas.getContext('2d');
            canvas.width = width;
            canvas.height = height;
            var base64;
            //  将图片画到canvas上面   使用Canvas压缩 
             canvas.setAttribute("width", width);
                                              canvas.setAttribute("height",height);
            ctx.drawImage(this, 0, 0, width, height);
            //var base64 = canvas.toDataURL(this.response.type, 0.2);
            var base64 = canvas.toDataURL('image/png',0.2);
            console.log(base64);//最终获得base64位
            console.log("到此了");
       };
    }else{<br>                                                               //此方法自行写 pathToBase64
            pathToBase64(f).then(res=>{
                console.log(res);直接转base64
            })
    }  

  

参考地址:

https://www.cnblogs.com/zhao1949/p/9177281.html

https://www.jq22.com/web-skill43

https://www.jb51.net/article/187561.htm

https://www.jianshu.com/p/d21193898339

https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLImageElement/Image

https://www.cnblogs.com/markor/articles/745281.html   [图片类处理]

posted @   小小强学习网  阅读(97)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示