Base64BlobFile 三种类型的相互转换
Posted freeman_Tian
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Base64BlobFile 三种类型的相互转换相关的知识,希望对你有一定的参考价值。
1、File 转 Base64
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<input type="file" name="file" id="file" multiple></br>
<button id="fileTobase">File 转 Base64</button><br>
<img id="img" src="" >
<script>
// 文件类型转base64
const fileToBase64 = (file, callback) => {
const reader = new FileReader();
reader.onload = function(evt) {
if(typeof callback === \'function\') {
callback(evt.target.result)
} else {
console.log("我是base64:", evt.target.result);
}
};
reader.readAsDataURL(file);
};
$("#fileTobase").click(function (e) {
e.preventDefault();
// 获取文件对象
const _file = $("#file")[0].files[0];
const base64 = fileToBase64(_file, base64 => {
console.log(\'我是base64:\', base64);
// 预览图片
$("#img").attr({"src": base64})
});
});
</script>
</body>
</html>
2、File 转 Blob
主要应用场景:文件上传
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>File 转 Blob</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<input type="file" name="file" id="file"></br>
<button id="fileToBlob">File 转 Blob</button><br>
<script>
// 文件类型转Blob
const fileToBlob = (file, callback) => {
const type = file.type;
const reader = new FileReader();
reader.onload = function(evt) {
const blob = new Blob([evt.target.result], {type});
if(typeof callback === \'function\') {
callback(blob)
} else {
console.log("我是 blob:", blob);
}
};
reader.readAsDataURL(file);
};
$("#fileToBlob").click(function (e) {
e.preventDefault();
// 获取文件对象
const _file = $("#file")[0].files[0];
fileToBlob(_file, blob => {
console.log(\'我是 blob:\', blob);
});
});
</script>
</body>
</html>
3、Base64 转 File
主要应用场景:文件上传
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Base64 转 File</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<img id="img" src="" srcset="">
<br>
<input style="display: none;" type="text" name="base64" id="base64" value="">
<br>
<button id="base64ToFile">Base64 转 File</button><br>
<script>
$("#img").attr({\'src\': $("#base64").val()})
// Base64 转 File
const base64ToFile = (base64, fileName) => {
let arr = base64.split(\',\'), type = 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});
};
$("#base64ToFile").click(function (e) {
e.preventDefault();
// 获取base64
const base64 = $("#base64").val();
console.log("我是 base64:", base64);
const file = base64ToFile(base64, \'fileName\');
console.log("我是 file:", file);
});
</script>
</body>
</html>
4、Base64 转 Blob
主要应用场景:文件上传
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Base64 转 Blob</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<img id="img" src="" srcset="">
<br>
<input style="display: none;" type="text" name="base64" id="base64" value="">
<br>
<button id="base64ToBlob">Base64 转 Blob</button><br>
<script>
$("#img").attr({\'src\': $("#base64").val()})
// Base64 转 Blob
const base64ToBlob = base64 => {
let arr = base64.split(\',\'), type = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while(n--){
u8arr[n] = bstr.charCodeAt(n);
}
return new Blob([u8arr], {type});
};
$("#base64ToBlob").click(function (e) {
e.preventDefault();
// 获取base64
const base64 = $("#base64").val();
console.log("我是 base64:", base64);
const blob = base64ToBlob(base64);
console.log("我是 Blob:", blob);
});
</script>
</body>
</html>
以上是关于Base64BlobFile 三种类型的相互转换的主要内容,如果未能解决你的问题,请参考以下文章