在 JavaScript 中,你可以使用多种方法将图片 URL 转换为 Base64 编码。以下是使用浏览器内置的 Fetch API 和 FileReader 的示例代码:
使用 Fetch API 和 FileReaderasync function convertImageToBase64(imageUrl) { // Fetch the image from the URL const response = await fetch(imageUrl); // Ensure the response is a blob (binary large object) const blob = await response.blob(); // Create a FileReader to read the blob as a data URL (Base64) const reader = new FileReader(); // Return a promise that resolves when the FileReader reads the blob return new Promise((resolve, reject) => { reader.onloadend = () => { resolve(reader.result); }; reader.onerror = reject; reader.readAsDataURL(blob); }); } // Example usage const imageUrl = 'https://example.com/path/to/image.jpg'; convertImageToBase64(imageUrl) .then(base64Image => { console.log('Base64 Image:', base64Image); }) .catch(error => { console.error('Error:', error); });说明Fetch API: 使用 fetch 从给定的图片 URL 获取响应。Blob: 将响应转换为 blob(二进制大对象),以便后续处理。FileReader: 使用 FileReader 对象将 blob 读取为 data URL(Base64 编码)。Promise: 返回一个 Promise,当 FileReader 读取完成时解析此 Promise,提供 Base64 编码的结果。使用 XMLHttpRequest 和 FileReader
另一种方法是使用 XMLHttpRequest 和 FileReader:
function convertImageToBase64(imageUrl) { return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); xhr.open('GET', imageUrl, true); xhr.responseType = 'blob'; xhr.onload = function() { if (xhr.status === 200) { const reader = new FileReader(); reader.onloadend = function() { resolve(reader.result); }; reader.onerror = reject; reader.readAsDataURL(xhr.response); } else { reject(new Error('Image load error')); } }; xhr.onerror = function() { reject(new Error('Network error')); }; xhr.send(); }); } // Example usage const imageUrl = 'https://example.com/path/to/image.jpg'; convertImageToBase64(imageUrl) .then(base64Image => { console.log('Base64 Image:', base64Image); }) .catch(error => { console.error('Error:', error); });说明XMLHttpRequest: 使用 XMLHttpRequest 对象发出 GET 请求以获取图片。Response Type: 将 responseType 设置为 blob 以接收二进制数据。FileReader: 使用 FileReader 对象将 blob 读取为 data URL(Base64 编码)。Promise: 返回一个 Promise,当 FileReader 读取完成时解析此 Promise,提供 Base64 编码的结果。
这两种方法都可以将图片 URL 转换为 Base64 编码,你可以根据你的需求选择适合的方法。
网友回复
DLNA与UPnP的区别和不同?
苏超自建抢票app,通过先预约再抽签化解高并发抢票?
python如何让给电脑在局域网中伪装成电视接收手机的投屏图片视频播放?
如何结合python+js如何自己的视频编码与加密播放直播?
python如何在电脑上通过局域网将本地视频或m3u8视频投屏电视播放?
腾讯视频爱奇艺优酷vip电影电视剧视频如何通过python绕过vip收费直接观看?
有没有可免费观看全球电视台直播m3u8地址url的合集?
有没有实现观影自由的免vip影视苹果 CMS V10 API的可用url?
python如何实时检测电脑usb插入检测报警?
如何判断真人操作的鼠标移动直线轨迹与机器操作的轨迹?