zoukankan      html  css  js  c++  java
  • 将url转化成file文件

     

            let img = "https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=508387608,2848974022&fm=26&gp=0.jpg"; //imgurl 就是你的图片路径
            let image = new Image();
            image.src = img;
            let self = this;
            image.setAttribute("crossOrigin", "Anonymous");
            image.onload = function () {
              var base64 = self.getBase64Image(image);
              // document.getElementById("img")['src'] = base64;
              var formData = new FormData();
              //转换base64到file
              var file = self.btof(base64, "test");
              console.log(file);
              file.url = self.initForm["coverUrl"];
              self.fileList.push(file);
              console.log(file)
              formData.append("imageName", file);
            };
     /** url 转换成img */
      getBase64Image(img): any {
        var canvas = document.createElement("canvas");
        canvas.width = img.width;
        canvas.height = img.height;
        var ctx = canvas.getContext("2d");
        ctx.drawImage(img, 0, 0, img.width, img.height);
        var ext = img.src.substring(img.src.lastIndexOf(".") + 1).toLowerCase();
        var dataURL = canvas.toDataURL("image/" + ext);

        return dataURL;
      }
      btof(data, fileName) {
        const dataArr = data.split(",");
        const byteString = atob(dataArr[1]);

        const options = {
          type: "image/jpeg",
          endings: "native"
        };
        const u8Arr = new Uint8Array(byteString.length);
        for (let i = 0; i < byteString.length; i++) {
          u8Arr[i] = byteString.charCodeAt(i);
        }
        return new File([u8Arr], fileName + ".jpg", options);
      }
    亲测有效,但是你的服务器地址得设置可以跨域,否则toDataUrl不能使用
  • 相关阅读:
    Elasticsearch之如何合理分配索引分片
    mybatis 批量插入 decimal精度问题
    在Java项目中打印错误日志的正确姿势
    Fork/Join框架原理
    AOP切面之打印方法时间
    转java之基础 equals和==比较
    Kibana
    基于mq搭建elk
    LogBack
    MongoD副本集(一)
  • 原文地址:https://www.cnblogs.com/qingcui277/p/12409559.html
Copyright © 2011-2022 走看看