gpt4 book ai didi

javascript - 如何在没有 FileReader 的情况下从 Blob 和 File 对象创建 ArrayBuffer 和数据 URI?

转载 作者:行者123 更新时间:2023-12-05 00:24:17 28 4
gpt4 key购买 nike

此问题与 How to updoad in old browsers (ex Safari 5.1.4) 相关并受其启发
给定一个 <input type="file">具有 files 的元素包含 File 的属性继承自 Blob 的对象, 是否可以创建 ArrayBuffer并转换 ArrayBufferdata URI来自 BlobFile不使用 FileReader 的对象?
迄今为止尝试过的方法是

  • 创建模拟 WebSocket.binaryType设置为 "arraybuffer" , 创建一个 MessageEventevent.data设置为 File目的;结果是 File对象位于 onmessage处理程序
  • 设置File的原型(prototype)至ArrayBuffer , Uint8Array ;结果是 Uncaught TypeError: Method ArrayBuffer.prototype.byteLength called on incompatible receiver #<ArrayBuffer>() , Uncaught TypeError: Method get TypedArray.prototype.byteLength called on incompatible receiver [object Object]()
  • 设置 FileFormData对象,尝试将请求正文发布到 <iframe> ,诚然没有精心构思;结果Bad Requestplnkr

  • 预期结果:转换 BlobFile反对 TypedArray然后到 data URL ,或直接发送至 data URL
    <!DOCTYPE html>
    <html>

    <head>
    </head>

    <body>
    <form method="get" entype="multipart/form-data" target="binaryFrame">
    <input id="#avatar" type="file" name="file" />
    <input type="submit" />
    </form>
    <iframe name="binaryFrame"></iframe>
    <script>
    var input = document.querySelector("input[type=file]");
    input.addEventListener("change", handleFiles, true);
    // see http://jsfiddle.net/adamboduch/JVfkt/
    var sock = new WebSocket("ws://mock");
    sock.binaryType = "arraybuffer";
    sock.onerror = function(e) {
    console.log("sock error", e); // ignore, here
    }

    sock.onmessage = function(e) {
    console.log("socket message", e.data, e.data instanceof ArrayBuffer);
    };

    function handleFiles(evnet) {
    var file = event.target.files[0];
    sock.dispatchEvent(new MessageEvent("message", {
    data: file
    }));
    var data = new FormData();
    data.append("file", file);
    document.forms[0].action = data;
    }
    </script>
    </body>

    </html>

    另见 Display image from blob using javascript and websockets , How can you encode a string to Base64 in JavaScript? ;有趣的是,我现在在问类似的问题 https://stackoverflow.com/questions/34302231/is-there-any-way-to-convert-the-file-to-an-arraybuffer-without-filereader-api ; Blob .slice() method , FileReader .readAsDataURL() method

    最佳答案

    我只是把它放在这里:

    var input = document.querySelector("input[type=file]");
    input.addEventListener("change", handleFiles, true);

    // for url
    window.URL = window.URL || window.webkitURL;

    function handleFiles(evnet) {
    var file = event.target.files[0];
    document.querySelector('iframe')
    .setAttribute('src', window.URL.createObjectURL(file));
    }
    <!DOCTYPE html>
    <html>
    <head>
    </head>
    <body>
    <form method="get" entype="multipart/form-data" target="binaryFrame">
    <input id="#avatar" type="file" name="file" />
    <input type="submit" />
    </form>
    <iframe name="binaryFrame"></iframe>
    </body>
    </html>

    关于javascript - 如何在没有 FileReader 的情况下从 Blob 和 File 对象创建 ArrayBuffer 和数据 URI?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38195855/

    28 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com