• Base64、Blob、File 三种类型的相互转换 最详细


    Base64、Blob、File 的API
    Base64
    Base64 是一组相似的二进制到文本(binary-to-text)的编码规则,使得二进制数据在解释成 radix-64 的表现形式后能够用 ASCII 字符串的格式表示出来。Base64 这个词出自一种 MIME 数据传输编码。

    Blob
    Blob 对象表示一个不可变、原始数据的类文件对象。Blob 表示的不一定是JavaScript原生格式的数据。File 接口基于Blob,继承了 blob 的功能并将其扩展使其支持用户系统上的文件。

    File
    File 接口提供有关文件的信息,并允许网页中的 JavaScript 访问其内容。

    通常情况下, File 对象是来自用户在一个 元素上选择文件后返回的 FileList 对象,也可以是来自由拖放操作生成的 DataTransfer 对象,或者来自 HTMLCanvasElement 上的 mozGetAsFile() API。在Gecko中,特权代码可以创建代表任何本地文件的File对象,而无需用户交互(有关详细信息,请参阅注意事项。

    File 对象是特殊类型的 Blob,且可以用在任意的 Blob 类型的 context 中。比如说, FileReader, URL.createObjectURL(), createImageBitmap(), 及 XMLHttpRequest.send() 都能处理 Blob 和 File。

    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="" alt="">
        <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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42

    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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40

    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="" alt="" 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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36

    4、Base64 转 Blob
    主要应用场景:文件上传

    //封装
    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 转 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 转 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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52

    5、Blob 转 File
    主要应用场景:文件上传

    // blob转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 转 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 转 File</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);
            };
    
            // Blob 转 File
            const blobToFile = (blob, fileName) => {
                const file = new File([blob], fileName, {type: blob.type});
                return file;
            }
    
            $("#fileToBlob").click(function (e) { 
                e.preventDefault();
                // 获取文件对象
                const _file = $("#file")[0].files[0];
                fileToBlob(_file, blob => {
                    console.log('我是 blob:', blob);
                    const file = blobToFile(blob, 'fileName');
                    console.log('我是 file', file);
                });
            });
        </script>
    </body>
    </html>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55

    6、Blob 转 base64
    主要应用场景:图片预览

    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 转 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 转 Base64</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);
            };
    
            // Blob 转 Base64
            const blobToBase64 = (blob, callback) => {
                let r = new FileReader();
                r.onload = function (e) {
                    if (typeof callback === 'function') {
                        callback(e.target.result);
                    } else {
                        console.log("我是 base64: ", e.target.result);
                    }
                }
                r.readAsDataURL(blob);
            }
    
            $("#blobToBase64").click(function (e) { 
                e.preventDefault();
                // 获取文件对象
                const _file = $("#file")[0].files[0];
                fileToBlob(_file, blob => {
                    console.log('我是 blob:', blob);
                    blobToBase64(blob, base64 => {
                        console.log("我是 base64: ", base64);
                    });
                });
            });
    
        </script>
    </body>
    </html>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
  • 相关阅读:
    Java内存区域
    Python3接口自动化测试项目实战(WEB项目)
    CodeFun 推出 PaaS 服务,携手腾讯 CoDesign 赋能前端
    网课搜题公众号 接口查题 查课接口 网课答案题库对接教程
    Django REST framework中的序列化Serializers
    LeetCode每日一题——1206. 设计跳表
    初识CSS
    [附源码]Python计算机毕业设计毕业生就业信息管理系统
    解决局域网内因为不在同一网段无法ping通的问题
    Python保留格式复制多个Excel工作表到汇总表并生成目录(附源码下载)
  • 原文地址:https://blog.csdn.net/m0_49515138/article/details/125907849