从uri获取图片文件的File对象


  1. 业务场景

    1. 需求: 复制一个模块, 该模块内容含有图片文件.
    2. 可提供的数据有: 该模块的相关信息(id等), 以及图片路径.
    3. 后台提供接口中, 需要传file字段.
  2. 知识储备

    1. xhr配置
    2. blob对象
    3. new File()方法
  3. 函数实现

//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;
}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM