>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 ArrayBuffer를 Base64 문자열로 효율적으로 변환하려면 어떻게 해야 합니까?

JavaScript에서 ArrayBuffer를 Base64 문자열로 효율적으로 변환하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-08 20:31:11755검색

How Can I Efficiently Convert an ArrayBuffer to a Base64 String in JavaScript?

ArrayBuffer를 Base64로 변환하기 위한 기본 구현

ArrayBuffer를 base64 인코딩 문자열로 변환하는 것은 멀티파트와 같은 다양한 사용 사례에 매우 중요합니다. POST 요청. 이를 효율적으로 수행하기 위해 개발자는 종종 기본 솔루션을 찾습니다.

솔루션

다음은 ArrayBuffer를 base64 문자열로 변환하는 효율적인 기본 함수입니다.

function _arrayBufferToBase64(buffer) {
    var binary = '';
    var bytes = new Uint8Array(buffer);
    var len = bytes.byteLength;
    for (var i = 0; i < len; i++) {
        binary += String.fromCharCode(bytes[i]);
    }
    return window.btoa(binary);
}

이 함수는 ArrayBuffer에서 바이너리 문자열을 생성하고 기본 btoa 함수를 사용하여 base64를 생성합니다. string.

대체 접근 방식

위의 솔루션은 기본이지만 기본이 아닌 구현은 더 나은 성능을 제공할 수 있습니다. 이러한 구현 중 하나는 여기에서 찾을 수 있습니다: https://gist.github.com/958841.

성능 벤치마크

공정한 비교를 위해 다음 성능을 참조하세요. 벤치마크:

  • http://jsperf.com/encoding-xhr-image-data/6
  • https://jsben.ch/wnaZC

위 내용은 JavaScript에서 ArrayBuffer를 Base64 문자열로 효율적으로 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.