JS上传图片前根据图片尺寸压缩后再上传

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <!-- layui框架 -->
    <link rel="stylesheet" href="layui/css/layui.css">    
    <script type="text/javascript" src="jquery.js"></script>
    <title>图片上传</title>
</head>
<body>


<button type="button" class="layui-btn" id="test1">
  <i class="layui-icon">&#xe67c;</i>上传图片
</button>
<script type="text/javascript" src="layui/layui.js"></script>
<script>
  layui.use('upload', function () {
    var upload = layui.upload;
    var layer = layui.layer; 
    //执行实例
    var uploadInst = upload.render({
      elem: '#test1', //绑定元素
      url: '图片上传接口', //上传接口
      accept: 'images',
      auto: false,
	  field:'uploadFile',
	  choose: function(obj){	
	    var that = this;	  
		obj.preview(function(index, file, result){
			var reader = new FileReader();
			reader.readAsDataURL(file);
			reader.onload = function(e) {
				dealImage(this.result, {width: 1024}, function (base) {
					var filet = dataURLtoFile(base, file.name);	
					that.data = {fileType:'productImg',id:'1'};				
					obj.upload(index,filet);
				});
			} 
		});
	  },	  
      done: function (res) {
        //上传完毕回调
      },
      error: function () {
        //请求异常回调
      }
    });
  });
 
/** 图片压缩 返回base64 */
function dealImage(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.75;  // 默认图片质量为0.9
        //生成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转file
 * filename图片的名字,dataurl是base64地址
 */
function dataURLtoFile(dataurl, filename) {
    var arr = dataurl.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 File([u8arr], filename, {type:mime});
}
 
</script>


</body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值