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不能使用
  • 相关阅读:
    CDH版本大数据集群下搭建的Hue详细启动步骤(图文详解)
    如何正确且成功破解跨平台数据库管理工具DbVisualizer?(图文详解)
    [转]【HTTP】Fiddler(二)
    [转]jQuery UI Dialog Modal Popup Yes No Confirm example in ASP.Net
    [转]artDialog
    [转]GridView排序——微软提供Sort
    [转]GridView中直接新增行、编辑和删除
    [转]asp.net的ajax以及json
    [转]JQuery Ajax 在asp.net中使用总结
    [转]Jquery easyui开启行编辑模式增删改操作
  • 原文地址:https://www.cnblogs.com/qingcui277/p/12409559.html
Copyright © 2011-2022 走看看