从uri获取图片文件的File对象
-
业务场景
- 需求: 复制一个模块, 该模块内容含有图片文件.
- 可提供的数据有: 该模块的相关信息(id等), 以及图片路径.
- 后台提供接口中, 需要传file字段.
-
知识储备
- xhr配置
- blob对象
- new File()方法
-
函数实现
//util.js
export function getImageFileFromUrl(url, imageName) {
// imageName一定要带上后缀
let p = new Promise((resolve, reject) => {
var blob = null;
var xhr = new XMLHttpRequest();
xhr.open("GET", url);
xhr.setRequestHeader('Accept', 'image/jpeg');
xhr.responseType = "blob";
xhr.onload = () => {
blob = xhr.response;
let imgFile = new File([blob], imageName, {type: 'image/jpeg'});
resolve(imgFile);
};
xhr.send();
});
return p;
}
行为影响状态,状态影响视图