Ant Design Upload组件通过beforeUpload属性可以在上传图片前进行处理。可以借助canvas对图片进行重缩放操作,然后返回Blob对象给组件进行上传。
具体的代码实现如下:
import { Upload } from 'antd';
function getBase64(file) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => resolve(reader.result);
reader.onerror = error => reject(error);
});
}
function resizeImage(file) {
return new Promise((resolve, reject) => {
const image = new Image();
image.src = URL.createObjectURL(file);
image.onload = () => {
// 重缩放为200x200
const canvas = document.createElement('canvas');
canvas.width = 200;
canvas.height = 200;
const ctx = canvas.getContext('2d');
ctx.drawImage(image, 0, 0, 200, 200);
canvas.toBlob(resolve, file.type);
};
image.onerror = reject;
});
}
function beforeUpload(file) {
return new Promise(async (resolve, reject) => {
try {
const resizedFile = await resizeImage(file);
const base64File = await getBase64(resizedFile);
resolve({
blobFile: resizedFile,
base64File: base64File
});
} catch (error) {
reject(error);
}
});
}
function uploadFile(file) {
console.log('Uploading file...', file);
}
function Demo() {
return (
{
if (info.file.status === 'done') {
uploadFile(info.file)
}
}} >
);
}
在beforeUpload方法中,首先调用resizeImage对图片进行重缩放操作,然后再使用getBase64将Blob对象转换为base64编码的字符串。最后将Blob对象和base64字符串打包成一个对象并返回给组件进行上传。
注意,在下面的uploadFile方法
上一篇:AntDesign图表中的堆叠条形图无法将条形标签向左移动。
下一篇:AntDesignv5我得到了一个“UncaughtTypeError:(0,_rcTable.genTable)isnotafunction”的错误提示。