js图片获取base64以及压缩

2 篇文章 0 订阅
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>图片获取base64以及压缩</title>
</head>

<body>
    <div>
        <input type="file" accept="image/*" name="file" id="file" onchange="checkPic(this)">
    </div>
    <div>
        <img src="" alt="" id="img" class="img" style="width: 400px;">
        <img src="" alt="" id="img1" class="img1" style="width: 400px;">
    </div>
    <script>
        function checkPic(e) {
            var file = e.files[0];
            var name = file.name;
            console.log("name:" + name);
            var size = file.size;
            console.log("size:" + size);
            var type = file.type;
            console.log("type:" + type);
            var lastModifiedDate = file.lastModifiedDate;
            console.log("lastModifiedDate:" + lastModifiedDate);
            var lastModified = file.lastModified;
            console.log("lastModified:" + lastModified);

            var base64 = getBase64(file);

            canvasDataURL("./../images/迪丽热巴 - 221.jpg");
        }

        //获取图片base64码
        function getBase64(file) {
            var reader = new FileReader();
            reader.readAsDataURL(file);
            reader.onloadend = function (e) {
                var base64 = e.target.result;
                console.log(e.target.result);
                console.log(base64.length)
                showPic(base64,"img");
            };
        }

        //展示图片
        function showPic(str,src) {
            document.getElementById(src).setAttribute("src", str);
        }

        function canvasDataURL(path) {
            var img = new Image();
            img.src = path;
            img.onload = function(){
                var that = this;
                // 默认按比例压缩
                var w = that.width;
                var h = that.height;

                if(w > 1024){
                    w = w / 40;
                    h = h / 40;
                }

                var quality = 0.7;  // 默认图片质量为0.7
                //生成canvas
                var canvas = document.createElement('canvas');
                var ctx = canvas.getContext('2d');
                // 创建属性节点
                var anw = document.createAttribute("width");
                anw.nodeValue = w;
                var anh = document.createAttribute("height");
                anh.nodeValue = h;
                canvas.setAttributeNode(anw);
                canvas.setAttributeNode(anh);
                ctx.drawImage(that, 0, 0, w, h);
    
                // quality值越小,所绘制出的图像越模糊
                var base64 = canvas.toDataURL('image/png', quality);
                // 回调函数返回base64的值
                showPic(base64,"img1");
                console.log(base64);
                console.log(base64.length);
            }
        }

    </script>
</body>

</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值