关于javascript:Base64BlobFile-三种类型的相互转换

185次阅读

共计 19348 个字符,预计需要花费 49 分钟才能阅读完成。

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>

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=""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>

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=""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>

正文完
 0