谷歌在 Chrome 74 中试验内置模块 KV Storage

阅读数:2595 2019 年 4 月 29 日

谷歌最近宣布,他们计划在 Chrome 的未来版本中交付两个新的WICG提案。KV Storage(键 - 值存储)试图提供 localStorage 的便利,但性能更好。其目的是利用导入映射提案将其作为内置模块的第一个示例交付。

JavaScript 生态系统在本地存储和缓存数据方面存在一些缺陷。正如谷歌 Web 平台软件工程师 Philip Walton 所解释的那样:

在过去十年的大部分时间里,浏览器厂商和 Web 性能专家一直在说,localStorage 很慢,Web 开发人员应该停止使用它。公平地说,说这话的人没错。LocalStorage 是一个同步 API,它会阻塞主线程,任何时候访问它都有可能阻止页面的交互。问题是,localStorage API 非常简单,而且 localStorage 的唯一异步替代方案是 IndexedDB,(面对现实吧)并不以其易用性或受欢迎的 API 而闻名。

Web Incubator CG (WICG)最近将 KV Storage 提升为 W3C IndexedDB 规范的一部分。KV Storage 类似于 localStorage,但更现代,并在 IndexedDB 之上。该规范要求浏览器厂商将其作为内置模块实现,并使用 IndexedDB 作为其后台存储。

以下是规范中提供的 KV Storage API 使用示例:

复制代码
import { storage } from "std:kv-storage"; // specifier prefix not final
(async () => {
await storage.set("mycat", "Tom");
console.assert(await storage.get("mycat") === "Tom");
for await (const [key, value] of storage.entries()) {
console.log(key, value);
}
// Logs "mycat", "Tom"
await storage.delete("mycat");
console.assert(await storage.get("mycat") === undefined);
})();

对于支持 IndexedDB 的浏览器,有一个KV Storage polyfill

KV Storage 模块是按照JavaScript 标准库提案及其导入映射支持中的定义实现的。

导入映射不是一个新概念,它是早期 JavaScript 模块系统的一部分,就像 AMD 和其他编程语言中的模块系统。它们是新近才包含在标准 ES 模块中的。这个导入映射提案提供了对 JavaScript import 语句和 import() 表达式所获取的 URL 的控制,并允许在非导入上下文中重用映射。导入映射允许简化导入语句、回退模块解析、内置模块 polyfill 以及在 fetch、image 和 link 标记之间共享上下文等等。

这两个备受期待的新特性的成功实现,将显著改进将特性添加到 JavaScript 未来版本的过程,并提供更加方便的 Web API。导入映射和内置模块完善了可扩展 Web 宣言中缺失的部分。

现在,希望试验 KV Storage 的开发人员可以利用 polyfill,或者安装 Chrome Dev 或 Chrome 74 的 Canary 版本。在这些特性的主流版本发布之前,开发者可以注册KV Storage 最初试用版,所有 Chrome 74+ 用户都可以使用这些特性。

查看英文原文Google Experiments With Key-Value Storage, Built-In Modules in Chrome 74

收藏

评论

微博

发表评论

注册/登录 InfoQ 发表评论