window.atob and window.btoa

本文详细介绍了Web API中关于解码的功能,特别是WindowOrWorkerGlobalScope的atob方法,该方法用于将Base64编码的数据字符串转换为二进制数据。这对于理解如何在浏览器环境中处理编码数据至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解码和解码

https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/atob


### JavaScript `window.atob` 函数的详细信息与用法 `window.atob` 是一个用于解码 Base64 编码字符串的内置 JavaScript 函数。它将 Base64 编码的字符串转换为原始字符串。如果输入的字符串包含无效字符或不是标准的 Base64 格式,该函数会抛出错误[^5]。 #### 语法 ```javascript window.atob(encodedString) ``` - **参数**: `encodedString` 是需要解码的 Base64 字符串。 - **返回值**: 返回解码后的原始字符串。 #### 示例代码 以下是一些使用 `window.atob` 的示例: ```javascript // 示例 1: 解码简单的 Base64 字符串 const encodedStr = "SGVsbG8gd29ybGQh"; // Base64 编码的 "Hello world!" const decodedStr = window.atob(encodedStr); console.log(decodedStr); // 输出: Hello world! // 示例 2: 尝试解码包含无效字符的字符串 try { const invalidEncodedStr = "SGVsbG8gd29ybGQh!"; // 包含无效字符 '!' const result = window.atob(invalidEncodedStr); console.log(result); } catch (e) { console.error("解码失败:", e.message); // 输出: 解码失败: Invalid character in input string } ``` #### 注意事项 1. `window.atob` 只能解码 ASCII 字符集中的内容。如果需要处理 Unicode 字符,请结合其他编码/解码方法。 2. 如果输入字符串中包含非 Base64 字符(例如空格或其他特殊符号),`window.atob` 会抛出 `InvalidCharacterError` 异常[^5]。 #### Unicode 处理扩展 对于包含 Unicode 字符的 Base64 字符串,可以结合 `Uint8Array` 和 `TextDecoder` 来正确处理: ```javascript function decodeBase64Unicode(base64String) { const binaryString = window.atob(base64String); const bytes = new Uint8Array(binaryString.length); for (let i = 0; i < binaryString.length; i++) { bytes[i] = binaryString.charCodeAt(i); } return new TextDecoder("utf-8").decode(bytes); } const base64UnicodeStr = "aGVsbG8gd29ybGQh"; // Base64 编码的 "hello world!" console.log(decodeBase64Unicode(base64UnicodeStr)); // 输出: hello world! ``` #### 相关知识点 在 JavaScript 中,除了 `window.atob` 之外,还有对应的 `window.btoa` 函数用于对字符串进行 Base64 编码[^5]。 ```javascript const originalStr = "Hello world!"; const encodedStr = window.btoa(originalStr); console.log(encodedStr); // 输出: SGVsbG8gd29ybGQh ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值