js图片url反转file文件 vue

场景

由于项目需求,需要将图片 url 转成文件格式上传到服务器

参考博客图片url转file

封装js

transferFile.js

bash 复制代码
function setInitImg(url,callback){
  let img = url;//这里是淘宝上随便找的一张图片
  let _ = this
  let imgRes
  getBase64(img, (dataURL) => {
    imgRes = dataURLtoFile(dataURL,img);
    console.log(imgRes)
    callback(imgRes)
  });
}

function getBase64(url, callback) {

//通过构造函数来创建的 img 实例,在赋予 src 值后就会立刻下载图片,相比 createElement() 创建 <img> 省去了 append(),也就避免了文档冗余和污染

var Img = new Image(),

dataURL = "";

Img.src = url + "?v=" + Math.random(); // 处理缓存,fix缓存bug,有缓存,浏览器会报错;

Img.setAttribute("crossOrigin", "Anonymous"); // 解决控制台跨域报错的问题

Img.onload = function () {

//要先确保图片完整获取到,这是个异步事件

var canvas = document.createElement("canvas"), //创建canvas元素

width = Img.width, //确保canvas的尺寸和图片一样

height = Img.height;

canvas.width = width;

canvas.height = height;

canvas.getContext("2d").drawImage(Img, 0, 0, width, height); //将图片绘制到canvas中

dataURL = canvas.toDataURL("image/jpeg"); //转换图片为dataURL

callback ? callback(dataURL) : null; //调用回调函数
};
}

function dataURLtoFile(dataurl, filename) {

//将base64转换为文件,dataurl为base64字符串,filename为文件名(必须带后缀名,如.jpg,.png)

var arr = dataurl.split(","),

mime = arr[0].match(/:(.*?);/)[1],

bstr = atob(arr[1]),

n = bstr.length,

u8arr = new Uint8Array(n);
while (n--) {

u8arr[n] = bstr.charCodeAt(n);
}
return new File([u8arr], filename, { type: mime });
}

export {

setInitImg
}

调用方式
bash 复制代码
import {setInitImg} from './transferFile'
setInitImg('https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg',(file)=>{
	   this.fileList.push(file)
 })

 
 
 
看一下转成的文件
相关推荐
JUNAI_Strive_ving4 分钟前
番茄小说逆向爬取
javascript·python
落落落sss8 分钟前
MybatisPlus
android·java·开发语言·spring·tomcat·rabbitmq·mybatis
看到请催我学习13 分钟前
如何实现两个标签页之间的通信
javascript·css·typescript·node.js·html5
简单.is.good26 分钟前
【测试】接口测试与接口自动化
开发语言·python
twins352032 分钟前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
Yvemil71 小时前
MQ 架构设计原理与消息中间件详解(二)
开发语言·后端·ruby
程序员是干活的1 小时前
私家车开车回家过节会发生什么事情
java·开发语言·软件构建·1024程序员节
qiyi.sky1 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~1 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
哪 吒1 小时前
华为OD机试 - 几何平均值最大子数(Python/JS/C/C++ 2024 E卷 200分)
javascript·python·华为od