Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Menukar Fail ke Rentetan Base64 dalam JavaScript?

Bagaimana untuk Menukar Fail ke Rentetan Base64 dalam JavaScript?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-02 04:59:09357semak imbas

How to Convert a File to a Base64 String in JavaScript?

Penukaran Fail ke Base64 dalam JavaScript

Menukar fail kepada rentetan base64 adalah penting untuk pelbagai aplikasi web. Dalam JavaScript, tugas ini boleh dicapai menggunakan kelas FileReader.

Masalah:

Seorang pengguna telah memperoleh objek Fail menggunakan querySelector dan bertujuan untuk menghantarnya melalui JSON dalam format base64. Persoalannya ialah bagaimana untuk menukar fail ini kepada rentetan base64.

Penyelesaian:

Untuk menukar fail kepada rentetan base64, gunakan kelas FileReader seperti berikut:

function getBase64(file) {
   var reader = new FileReader();
   reader.readAsDataURL(file);
   reader.onload = function () {
     console.log(reader.result); // Base64 string
   };
   reader.onerror = function (error) {
     console.log('Error: ', error);
   };
}

var file = document.querySelector('#files > input[type="file"]').files[0];
getBase64(file);

Dalam kod ini, fungsi getBase64 memulakan tika FileReader dan bermula membaca fail sebagai URL data. Apabila operasi membaca selesai, pengendali acara onload dipanggil dan ia mencetak rentetan base64 ke konsol.

Perhatikan bahawa fail yang diperoleh melalui querySelector ialah objek Fail, subkelas Blob, menjadikannya serasi dengan kelas FileReader. Contoh kerja lengkap tersedia untuk rujukan.

Atas ialah kandungan terperinci Bagaimana untuk Menukar Fail ke Rentetan Base64 dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn