前端开发必备:深入理解btoa和atob函数
创作时间:
作者:
@小白创作中心
前端开发必备:深入理解btoa和atob函数
引用
CSDN
等
8
来源
1.
https://blog.csdn.net/qq_36380426/article/details/138174248
2.
https://blog.csdn.net/weixin_44283589/article/details/132165045
3.
https://cloud.baidu.com/article/3320935
4.
https://blog.csdn.net/carcarrot/article/details/100705946
5.
https://www.zhangxinxu.com/wordpress/2018/08/js-base64-atob-btoa-encode-decode/comment-page-1/
6.
https://www.cnblogs.com/djane/articles/10857826.html
7.
https://my.oschina.net/emacs_8600208/blog/16740193
8.
https://www.cnblogs.com/ziChin/p/17897499.html
在前端开发中,btoa
和 atob
是两个非常实用的全局函数,主要用于处理 Base64 编码和解码。它们在数据传输、存储以及安全场景中发挥重要作用。本文将深入解析这两个函数的使用方法、应用场景以及注意事项。
基本功能与使用
btoa
和 atob
的名称和功能可以这样理解:
函数名 | 全称 | 输入 → 输出 | 作用 |
---|---|---|---|
btoa | Binary to ASCII | 二进制字符串 → Base64 字符串 | 编码 |
atob | ASCII to Binary | Base64 字符串 → 二进制字符串 | 解码 |
基本用法示例
const text = "Hello, world!";
const base64Text = btoa(text); // "SGVsbG8sIHdvcmxkIQ=="
const decodedText = atob(base64Text); // "Hello, world!"
实际应用场景
1. 数据传输
在不支持二进制数据的系统之间传输数据时,可以使用 Base64 编码。例如,在 WebSocket 中传输音频数据:
// 发送音频数据前编码
const audioData = new Uint8Array([...]);
const base64Audio = btoa(String.fromCharCode(...audioData));
socket.send(base64Audio);
// 接收后解码
socket.onmessage = (event) => {
const binaryData = atob(event.data);
const audioBlob = new Blob([binaryData], {type: 'audio/mpeg'});
// 播放音频
};
2. 图片数据处理
可以直接在 HTML 中嵌入 Base64 编码的图片:
<img src="
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot">
3. 跨域通信
在需要绕过浏览器的同源策略时,可以使用 Base64 编码来传输数据。
Unicode 字符处理
btoa
不能直接处理 Unicode 字符,比如中文。需要先进行 URI 编码:
// 错误用法(直接编码中文会报错)
btoa("中文"); // ❌ 报错:InvalidCharacterError
// 正确做法:先转码
function utf8ToBase64(str) {
return btoa(unescape(encodeURIComponent(str)));
}
function base64ToUtf8(base64) {
return decodeURIComponent(escape(atob(base64)));
}
utf8ToBase64("你好"); // "JUU0JUJEJUEwJUU1JUE1JUJE"
base64ToUtf8("JUU0JUJEJUEwJUU1JUE1JUJE"); // "你好"
性能优化
对于大文件,可以采用分块处理的方式避免内存溢出:
async function encodeLargeFile(file) {
const chunkSize = 1024 * 1024; // 1MB
let offset = 0;
while (offset < file.size) {
const chunk = file.slice(offset, offset + chunkSize);
const arrayBuffer = await chunk.arrayBuffer();
const base64Chunk = btoa(String.fromCharCode(...new Uint8Array(arrayBuffer)));
// 发送或存储 base64Chunk
offset += chunkSize;
}
}
兼容性解决方案
btoa
和 atob
在 IE10+ 及所有现代浏览器中都支持。对于 IE8/IE9,可以使用 polyfill:
<!--[if IE]>
<script src="./base64-polyfill.js"></script>
<![endif]-->
或者提供替代实现:
if (!window.atob) {
window.atob = function(encodedString) {
// 替代实现代码
};
}
总结对比表
特性 | btoa | atob |
---|---|---|
方向 | 编码 → Base64 | 解码 → 原始数据 |
输入类型 | 二进制字符串 | Base64 字符串 |
Unicode 支持 | 需手动转码(UTF-8 → 字节) | 需手动转码(字节 → UTF-8) |
适用场景 | 文本/二进制数据的文本化传输 | 还原编码后的数据 |
浏览器兼容性 | 所有现代浏览器 | 所有现代浏览器 |
通过本文的介绍,相信你已经掌握了 btoa
和 atob
的使用方法和注意事项。在实际开发中,合理运用这两个函数,可以让你的数据处理更加高效和灵活。
热门推荐
NBA选秀模板大盘点:从詹姆斯到姚明,谁被高估了?
958爱情代表什么意思?解读数字与情感的关联
想把“衬衫+半身裙”穿出高级感不难,看12套穿搭示范,谁穿谁美
镇远古城一日游:探寻历史与文化的魅力之旅
旧衣服回收后都去哪了?
伊犁州全力打好春耕备耕“主动仗”
什么是老年性黄斑变性?怎么预防?
NVMe 2.1规范发布:统一存储架构、简化开发流程、增强安全和管理
给厂家供货如何签合同:全面解析与法律实务指南
预防肌肉疼痛和伤病?这样拉伸是错误的
A型、B型、O型、AB型,哪种血型的人最健康?血型决定性格?真相太让人意外
龙族卡塞尔之门:小巫女诺诺(陈墨瞳)角色深度解析
属土男孩如何通过易经起名?属土的卦象解析与命名指南
佛手的室内养护指南(室内养佛手)
汽车悬架系统结构原理概述及分类
月柱被大运天合地合,流年干支与月柱天合地合
起诉欠款人调解流程及法律要点详解
退休人员取得工资薪金所得是否需要缴纳个人所得税?
银川至重庆火车路线及购票攻略:全面解析如何规划行程与选择更优车次
童笔绘画顾氏老宅!"绘行周浦"活动走进百年绞圈房
25款儿童牙膏安全性良好 中消协建议3岁以下儿童尽量选择无氟产品
吹风机使用指南:全方位掌握正确吹发技巧与安全注意事项
肝胆外科主要治疗哪些疾病
漫威:未来之战【杂谈】《X战警:黑凤凰》映前科普!揭秘琴格雷与凤凰之力的故事
电子技术实验手册:电感的交流特性与感抗测量
不同类型疫苗的价格有何差异?
血压,你量对了吗?
耳塞哪里有卖?耳塞怎么选择合适的?
嵌入式系统开发芯片有哪些
什么是土壤盐碱化?如何解决?