elementUI上传图片前判断图片的尺寸大小
2020-07-11 本文已影响0人
冷r
在上传图片前判断尺寸的大小,遇到了好多的坑。
1.没有注意到onload是异步加载,所以一定要在onload后在执行判断图片尺寸
2.upload内部需要一个promise,简单的return出false并没有什么用
data:image/s3,"s3://crabby-images/c2426/c24268d298455bbd3bcdba7df08ff7c3474c4b56" alt=""
完整代码如下:
beforeUpload(file) {
const _URL = window.URL || window.webkitURL
const isSize = new Promise((resolve, reject) => {
const img = new Image()
img.onload = function() {
this.width > 500 ? reject() : resolve()
}
img.src = _URL.createObjectURL(file)
}).then(
() => {
return file
},
() => {
this.$message({
type: 'error',
message: '图片宽度不能超过500'
})
return Promise.reject()
}
)
return isSize
}