js图片压缩后上传

 <input id="uploadFile" class="uploader-input" type="file" name="uploadFile" accept="image/*"    multiple="multiple" οnchange="uploadFile();">


function uploadFile(){
    var lengli = $("#uploaderFiles li").length;
    if(lengli >= 3){
        mui.toast("上传图片不得超过三张");
        return;
    }
    var formData = new FormData();
    var file = $("#uploadFile")[0].files[0];
    //图片压缩上传,大于1.2M压缩图片
    if (file.size / 1024 > 1024 * 1.2) {
        console.log('开始压缩');
        photoCompress(file, {
            quality: 0.3  //默认图片质量为0.3 quality值越小,所绘制出的图像越模糊
        }, function(base64Codes){
            var bl = convertBase64UrlToBlob(base64Codes);
            formData.append("uploadFile", bl, file.name); // 文件对象
            uploadAdd(formData)
        });

    }else{
        formData.append("uploadFile", file); // 文件对象
        uploadAdd(formData)
    }
}


/**
 * 上传
 * @param formData             
 */
function uploadAdd(formData){
    var lengli = $("#uploaderFiles li").length;
    var URL = urls.uploadFile + "?fileType=image&plateTag=ruipn&fileOwnerId=ruipn&token="+app.getToken();
    $.ajax({
        url: URL, //请求地址
        type: "post",
        async: true, //默认为异步
        data: formData, //参数
        contentType: false, //数据请求格式
        processData:false,
        //dataType:'json',//响应格式
        success: function (resq) {
            if(resq.status == "0000"){
                mui.toast("上传成功");
                var number = lengli+1;
                $('#image'+number).val(resq.multimediaObj.path);
                $('#uploaderFiles').append("<li class='uploader-file'><img src="+app.fileBase+resq.multimediaObj.path+" ></li>"); 
            }
        },
        error: function(rep) {
            console.log(JSON.stringify(rep));
        }
    });
}


/*
三个参数
file:一个是文件(类型是图片格式),
w:一个是文件压缩的后宽度,宽度越小,字节越小
objDiv:一个是容器或者回调函数
photoCompress()
 */
function photoCompress(file,w,objDiv){
    var ready=new FileReader();
    /*开始读取指定的Blob对象或File对象中的内容. 当读取操作完成时,readyState属性的值会成为DONE,如果设置了onloadend事件处理程序,则调用之.同时,result属性中将包含一个data: URL格式的字符串以表示所读取文件的内容.*/
    ready.readAsDataURL(file);
    ready.οnlοad=function(){
        var re=this.result;
        canvasDataURL(re,w,objDiv)
    }
}
function canvasDataURL(path, obj, callback){
    var img = new Image();
    img.src = path;
    img.onload = function(){
        var that = this;
        // 默认按比例压缩
        var w = that.width,
            h = that.height,
            scale = w / h;
        w = obj.width || w;
        h = obj.height || (w / scale);
        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);
        // 图像质量
        if(obj.quality && obj.quality <= 1 && obj.quality > 0){
            quality = obj.quality;
        }
        // quality值越小,所绘制出的图像越模糊
        var base64 = canvas.toDataURL('image/jpeg', quality);
        // 回调函数返回base64的值
        callback(base64);
    }
}

/**
 * 将以base64的图片url数据转换为Blob
 * @param urlData
 *            用url方式表示的base64图片数据
 */
function convertBase64UrlToBlob(urlData){
    var arr = urlData.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], {type:mime});
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值