图片上传压缩

localResizeIMGUploader 图片上传
.catch(function (err) {
/* 处理失败后执行 /
}).always(function () {
/
必然执行 */
})

npm 安装

npm install lrz

main.js

import lrz from 'lrz'

lrz(file, [options])
    .then(function (rst) {
        // 处理成功会执行
        console.log(rst);
    })
    .catch(function (err) {
        // 处理失败会执行
    })
    .always(function () {
        // 不管是成功失败,都会执行
    });

压缩图片:lrz(file, [options]);

file 通过 input:file 得到的文件,或者直接传入图片路径
[options] 这个参数允许忽略
width {Number} 图片最大不超过的宽度,默认为原图宽度,高度不设定时会适应宽度
height {Number} 图片的最大高度,默认为原图高度
quality {Number} 图片压缩质量,取值 0 - 1,默认为 0.7
fieldName {String} 后端接收的字段名,默认:file

返回结果:promise 对象

then(rst) 处理成功后执行

rst.formData 后端可处理的数据
    rst.file 压缩后的file对象,如果压缩率太低,将会是原始file对象
    rst.fileLen 生成后的图片的大小,后端可以通过此值来校验是否传输完整
    rst.base64 生成后的图片base64,后端可以处理此字符串为图片,也可以直接用于 img.src = base64
    rst.base64Len 生成后的base64的大小,后端可以通过此值来校验是否传输完整
    rst.origin 也就是原始的file对象,里面存放了一些原始文件的信息,例如大小、日期等

异步上传:processData 和 contentType 必须设为 false,否则服务端不会响应

猜你喜欢

转载自blog.csdn.net/weixin_43848576/article/details/89157232