以下是您需要知晓的相关信息:
WebTransport
是一种用于在客户端和服务器之间发送实时消息的新选项。- 您可以使用功能检测来查看浏览器支持哪些类型的脚本。
- 从数组末尾搜索变得更容易一些。
- 还有许多其他功能。
新年快乐!我是 Pete LePage。我们来深入了解一下 Chrome 97 中面向开发者的新功能。
Web Transport
如果您使用 Web Sockets 或 WebRTC Data Channel API 在服务器和网页之间发送消息,则可以使用新的选项。WebTransport
是一个新 API,可提供低延迟、双向的客户端-服务器消息传递。
与 WebSocket 相比,Web Transport API 的延迟时间更短。与专为点对点消息传递而设计的 RTC Data Channel API 不同,Web Transport API 专为客户端-服务器消息传递而设计。
它支持使用流 API 可靠地发送数据,以及使用数据报 API 不可靠地发送数据。Web Worker 支持此功能。由于它公开了符合 Streams 规范的接口,因此支持针对回压进行优化。
如需使用它,您需要一台支持 HTTP/3 的服务器,这通常比设置和维护 WebRTC 服务器更容易。打开新的 WebTransport
实例,等待其连接,然后即可开始发送数据。
const url = 'https://example.com:4999/foo/bar';
const transport = new WebTransport(url);
await transport.ready;
const writer = transport.datagrams.writable.getWriter();
const data1 = new Uint8Array([65, 66, 67]);
writer.write(data1);
如需了解完整详情,请参阅 web.dev 上的试用 WebTransport 一文。
脚本类型特征检测
现在,我们可以使用 nomodule
属性在浏览器中检测对 JavaScript 模块的支持。不过,我们正在考虑推出多项新功能,例如导入映射、推测规则和软件包预加载。我们需要一种方法来了解浏览器支持的内容。
输入 HTMLScriptElement.supports()
。您可以使用它来确定可以使用哪些类型的脚本,并向浏览器发送最佳选项。
if (HTMLScriptElement.supports('importmap')) {
// Use <script type="importmap" ...>
} else if (HTMLScriptElement.supports('module')) {
// Use <script type="module" ...>
} else {
// Use classic method...
}
新的数组原型
我很高兴 JavaScript 变得更简单。Array
和 TypedArray
现在支持 findLast()
和 findLastIndex()
静态方法。
这些函数实际上与 find()
和 findIndex()
相同,但会从数组的末尾(而非开头)开始搜索。
例如,如需查找数组中大于 10 的最后一个数字,请使用用于检查值是否大于 10 的测试函数调用 findLast()
,即可顺利完成。
const array1 = [5, 12, 8, 130, 44, 3, 6];
function greaterThanTen(val) {
return val > 10;
}
const last = array1.findLast(greaterThanTen);
// 44
const lIdx = array1.findLastIndex(greaterThanTen);
// 4
在 UA 字符串中模拟 Chrome 100
短短几个月后,我们将迎来 Chrome 100,这是个三位数版本号。 应检查用于检查版本号或解析 UA 字符串的所有代码,确保其能够处理三位数。
有一个名为 #force-major-version-to-100
的标志,会将当前版本号更改为 100,以便您确保一切都能按预期运行。
等等!
当然,还有许多其他功能。
表单条目中的新行现在会采用与 Gecko 和 WebKit 相同的方式进行规范化,从而改善浏览器之间的互操作性。
我们将为客户端提示名称添加 sec-ch
前缀,以使其标准化。例如,dpr
会变为 sec-ch-dpr
。我们将继续支持这些提示的现有版本,但您应做好最终弃用和移除这些提示的准备。
关闭的 <details>
元素现在可供搜索,并且可以链接到。使用“在页面中查找”“ScrollToTextFragment
”和元素 fragment 导航时,这些隐藏元素会自动展开。
深入阅读
本文仅介绍了一些主要亮点。如需了解 Chrome 97 中的其他变更,请参阅以下链接。
- Chrome DevTools (97) 中的新变化
- Chrome 97 弃用和移除的功能
- ChromeStatus.com 上有关 Chrome 97 的最新动态
- Chrome 97 中的 JavaScript 新变化
- Chromium 源代码库更改列表
- Chrome 发布日历
订阅
如需及时了解最新动态,请订阅 Chrome 开发者 YouTube 频道,这样每当我们发布新视频时,您就会收到电子邮件通知。
我是 Pete LePage,Chrome 98 发布后,我会立即为您介绍 Chrome 中的新变化!