当前位置:网站首页>The most detailed conversion of Base64, blob and file
The most detailed conversion of Base64, blob and file
2022-07-22 17:07:00 【No overtime at the front end】
Base64、Blob、File Of API
Base64
Base64 Is a similar set of binary to text (binary-to-text) The coding rules of , So that binary data is interpreted as radix-64 After the form of expression can be used ASCII The format of the string is expressed .Base64 This word comes from a kind of MIME Data transmission code .
Blob
Blob Object represents an immutable 、 Class file object of original data .Blob Not necessarily JavaScript Data in native format .File Interface based on Blob, Inherited blob And extend it to support files on the user's system .
File
File The interface provides information about the file , And allow JavaScript Access its content .
Usually , File Objects are from users in a Element is returned after selecting a file FileList object , It can also be generated by free drag and drop operations DataTransfer object , Or from HTMLCanvasElement Upper mozGetAsFile() API. stay Gecko in , Privileged code can create File object , Without user interaction ( For more information , Please refer to precautions .
File Objects are special types of Blob, And can be used in any Blob Type of context in . for instance , FileReader, URL.createObjectURL(), createImageBitmap(), And XMLHttpRequest.send() Can handle Blob and File.
1、File turn Base64
Main application scenarios : Preview picture
<!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 turn Base64</button><br>
<img id="img" src="" alt="">
<script>
// Document type to base64
const fileToBase64 = (file, callback) => {
const reader = new FileReader();
reader.onload = function(evt) {
if(typeof callback === 'function') {
callback(evt.target.result)
} else {
console.log(" I am a base64:", evt.target.result);
}
};
reader.readAsDataURL(file);
};
$("#fileTobase").click(function (e) {
e.preventDefault();
// Get file object
const _file = $("#file")[0].files[0];
const base64 = fileToBase64(_file, base64 => {
console.log(' I am a base64:', base64);
// The preview image
$("#img").attr({
"src": base64})
});
});
</script>
</body>
</html>
2、File turn Blob
Main application scenarios : Upload files
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>File turn 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 turn Blob</button><br>
<script>
// Document type to 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(" I am a blob:", blob);
}
};
reader.readAsDataURL(file);
};
$("#fileToBlob").click(function (e) {
e.preventDefault();
// Get file object
const _file = $("#file")[0].files[0];
fileToBlob(_file, blob => {
console.log(' I am a blob:', blob);
});
});
</script>
</body>
</html>
3、Base64 turn File
Main application scenarios : Upload files
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Base64 turn File</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<img id="img" src="" alt="" srcset="">
<br>
<input style="display: none;" type="text" name="base64" id="base64" value="">
<br>
<button id="base64ToFile">Base64 turn File</button><br>
<script>
$("#img").attr({
'src': $("#base64").val()})
// Base64 turn 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();
// obtain base64
const base64 = $("#base64").val();
console.log(" I am a base64:", base64);
const file = base64ToFile(base64, 'fileName');
console.log(" I am a file:", file);
});
</script>
</body>
</html>
4、Base64 turn Blob
Main application scenarios : Upload files
// encapsulation
const base64ToBlob = function (base64Data) {
let arr = base64Data.split(','),
fileType = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[1]),
l = bstr.length,
u8Arr = new Uint8Array(l)
while (l--) {
u8Arr[l] = bstr.charCodeAt(l)
}
return new Blob([u8Arr], {
type: fileType
})
}
//
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Base64 turn Blob</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
</head>
<body>
<img id="img" src="" alt="" srcset="">
<br>
<input style="display: none;" type="text" name="base64" id="base64" value="">
<br>
<button id="base64ToBlob">Base64 turn Blob</button><br>
<script>
$("#img").attr({
'src': $("#base64").val()})
// Base64 turn 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();
// obtain base64
const base64 = $("#base64").val();
console.log(" I am a base64:", base64);
const blob = base64ToBlob(base64);
console.log(" I am a Blob:", blob);
});
</script>
</body>
</html>
5、Blob turn File
Main application scenarios : Upload files
// blob turn file
const blobToFile = function (newBlob, fileName) {
newBlob.lastModifiedDate = new Date()
newBlob.name = fileName
return newBlob
}
//
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Blob turn File</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">Blob turn File</button><br>
<script>
// Document type to 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(" I am a blob:", blob);
}
};
reader.readAsDataURL(file);
};
// Blob turn File
const blobToFile = (blob, fileName) => {
const file = new File([blob], fileName, {
type: blob.type});
return file;
}
$("#fileToBlob").click(function (e) {
e.preventDefault();
// Get file object
const _file = $("#file")[0].files[0];
fileToBlob(_file, blob => {
console.log(' I am a blob:', blob);
const file = blobToFile(blob, 'fileName');
console.log(' I am a file', file);
});
});
</script>
</body>
</html>
6、Blob turn base64
Main application scenarios : Preview picture
export function blobToBase64 (blob, callback) {
var reader = new FileReader()
reader.onload = function () {
var dataUrl = reader.result
var base64 = dataUrl.split(',')[1]
callback(base64)
}
reader.readAsDataURL(blob)
};
//
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Blob turn Base64</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="blobToBase64">Blob turn Base64</button><br>
<script>
// Document type to 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(" I am a blob:", blob);
}
};
reader.readAsDataURL(file);
};
// Blob turn Base64
const blobToBase64 = (blob, callback) => {
let r = new FileReader();
r.onload = function (e) {
if (typeof callback === 'function') {
callback(e.target.result);
} else {
console.log(" I am a base64: ", e.target.result);
}
}
r.readAsDataURL(blob);
}
$("#blobToBase64").click(function (e) {
e.preventDefault();
// Get file object
const _file = $("#file")[0].files[0];
fileToBlob(_file, blob => {
console.log(' I am a blob:', blob);
blobToBase64(blob, base64 => {
console.log(" I am a base64: ", base64);
});
});
});
</script>
</body>
</html>
边栏推荐
- 视觉系统设计实例(halcon-winform)-8.匹配查找
- [MySQL] SQL tuning practice teaching
- Overview of basic principles of network
- numpy.ascontiguousarray
- QT warning: c4819: this file contains characters that cannot be represented in the current code page (936). Please save the file in Unicode format to prevent data loss
- Contract awarding and use of NPM private server
- [论文翻译] Generalized Radiograph Representation Learning via Cross-Supervision Between Images
- 进程与线程的区别
- 汉得企业级数字化PaaS平台 HZERO 1.9.0 版本正式发布!
- Qt5.9.2初次导入使用msvc2017_64编译器遇到的问题记录
猜你喜欢
Mecol Studio - harmonyos second assignment
使用OpenCV实现哈哈镜效果
汉得企业级PaaS平台HZERO即将重磅开源!
【Redis】分布式场景下Redis高可用部署方案
Hande enterprise PAAS platform hzero released version 1.5.0.release
Opencv supports H264 video coding
[open hand] hande enterprise PAAS platform hzero heavy open source!
数据湖:数据湖技术架构演进
禅道管理员忘记密码找回密码
通过删除注册表破解plsql
随机推荐
UE4 创建一个工程
[论文翻译] Generalized Radiograph Representation Learning via Cross-Supervision Between Images
numpy.random.seed()
1840. 最高建筑高度 贪心
Cross domain problem (CORS) detailed description and solution
Hande x Jiuli special materials | work together to create a collaborative office portal and help it internal standardized management
numpy.random.seed()
Upgrade MySQL 5.6 to 8.0 on Windows
codeforce D2. RGB Substring (hard version) 滑動窗口
mysql基础+mysql集群复习
tf.placeholder
Inventory of e-mail security incidents in China in the first half of 2022
codeforce D2. RGB Substring (hard version) 滑动窗口
MySQL query plan key_ How to calculate len
Concis component library | dark pattern design
LVS, this is enough
tf.reduce_sum()
Ora-16525 DG broker not available
[vs] trying to load a program with incorrect format
5分钟带你浅谈企业级PaaS平台HZERO!