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不能使用
  • 相关阅读:
    webpack learn2-vue的jsx写法和postcss 1
    浏览器缓存旧的js文件或css文件导致没出现预期效果
    webpack learn1-webpack-dev-server的配置和使用3
    Python正课60 —— configparser模块
    Python正课59 —— json与pickle模块
    Python正课58 —— 小说阅读项目 初级
    Python正课57 —— ATM+购物车 前戏
    Python正课56 —— shutil模块
    Python正课55 —— sys模块
    Python正课54 —— os模块
  • 原文地址:https://www.cnblogs.com/qingcui277/p/12409559.html
Copyright © 2011-2022 走看看