表单中 / 自定义页面中图片裁剪后上传
本案例来自来自三方开发者「冯鹏」
1. 使用场景
当我们上传的图片需要做一些裁剪处理时,可参考本例。
2. 实现功能
下述操作除了对话框需要从自定义页面复制到表单页面,其余操作表单 / 自定义页面相同。
2.1 引入三方JS资源和CSS资源
data:image/s3,"s3://crabby-images/2cc55/2cc55c89da59752441b10e980289e5d2ae4700fb" alt=""
this.utils.loadStyleSheet('https://g.alicdn.com/yida-platform/react-cropper/1.0.0/css/react-cropper.css');
this.utils.loadScript('https://g.alicdn.com/yida-platform/react-cropper/1.0.0/js/react-cropper.js');
2.2 配置表单 / 自定义页面
注意关闭自动上传。
data:image/s3,"s3://crabby-images/0469a/0469af602358903205864b67c748730aaa1b31a8" alt=""
2.3 配置用到的变量
data:image/s3,"s3://crabby-images/50aaa/50aaae86566dd9f5236c6688055a0912a4e6e3d2" alt=""
2.4 配置裁剪用到的对话框
data:image/s3,"s3://crabby-images/a0357/a03571699c831ccf10077ef6aba2507a2dc06a5f" alt=""
JSX组件内代码如下:
function render() {
return(
<window.ReactCropper
ref={this.saveCropperrRef.bind(this)}
src={this.state.src}
style={{ height: 300, width: 400 }}
/>
);
}
对话框事件绑定:
data:image/s3,"s3://crabby-images/fb3a2/fb3a26e16c3c62e197a70af75d217bbdc86503cd" alt=""
OnOk事件代码如下:
注意修改第4行中的图片上传组件唯一标识和第14行中的对话框组件唯一标识。
export function onOk() {
const data = this.state.cropperRef.cropper.getCroppedCanvas().toDataURL();
const file = dataURL2Blob2File(data, this.state.file);
let uploaderRef = this.utils.isMobile() ? this.$('imageField_l9ozo0n1').uploaderRef.uploaderRef : this.$('imageField_l9ozo0n1').uploaderRef;
console.log('file', file);
if (uploaderRef.state.value) {
uploaderRef.state.value.forEach(_file => {
if (_file && _file.uid === file.uid) {
_file.size = file.size;
}
});
}
uploaderRef.uploaderRef.startUpload([file]);
this.$('dialog_kqby9wqe').hide();
}
2.5 将下面代码拷贝至页面JS中
注意将18行的对话框组件唯一标识。
export function onSuccess(file, value) {
this.utils.toast({
title: '上传成功'
});
}
/**
* imageField onSelect
*/
export function onSelect(files) {
console.log('onSelect');
const reader = new FileReader();
reader.onload = () => {
this.setState({
src: reader.result,
file: files[0],
});
this.$('dialog_kqby9wqe').show();
};
reader.readAsDataURL(files[0].originFileObj);
}
/**
* 图片剪切开始
*/
export function saveCropperrRef(ref) {
this.setState({
cropperRef: ref,
});
}
function dataURL2Blob2File(dataURL, file) {
const arr = dataURL.split(","),
mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[1]),
u8arr = new Uint8Array(bstr.length);
let n = bstr.length;
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
const blob = new Blob([u8arr], { type: mime });
// Blob to File
// set lastModifiedDate and name
blob.lastModifiedDate = new Date();
blob.name = file.name;
blob.uid = file.uid;
return blob;
}
2.6 图片上传组件动作绑定
data:image/s3,"s3://crabby-images/8f7ae/8f7aedb2f55c8467d8611e7c8c18178f21010182" alt=""
3. 实现效果
data:image/s3,"s3://crabby-images/07e58/07e58509fe98c521533454e21da5a785d749fd2a" alt=""
4. 在线试玩
本文档对您是否有帮助?