Chrome 88 重要更新解读

简介: 2021年1月19日,时隔两个月后,Chrome 发布 M88,一起来看看此版本的重大更新。
作者| 彼洋

2021年1月19日,时隔两个月后,Chrome 发布 M88。该版本的显著特点是,几个比较大的下线计划终于完成,包括FTP、Flash、WebComponents v0、混合内容下载等。

新增稳定功能

Manifest v3

Chrome 88 现在支持使用 Manifest v3 构建的扩展程序,用户可以将其上传到 Chrome 网上应用商店。Manifest v3 是一个新的扩展平台,可使 Chrome 扩展更安全,更高效,更尊重隐私。

比如,Manifest v3 不允许使用远程托管的代码,这可以帮助 Chrome Web Store 审核人员更好地了解扩展程序带来的风险,并且允许你更快地更新扩展。

又如,它引入了service worker,来取代后台页面,因为 service worker 只会按需存在于内存中,它会占用更少的系统资源。

更多信息,请移步链接(https://developer.chrome.com/docs/extensions/mv3/ ),它会告诉你如何把现有扩展迁移到manifest v3。

CSS aspect-ratio 属性

在以前,只有某些特定的元素具有长宽比,例如 image。对于它们,我们仅需指定宽度或高度,元素会根据固有长宽比自动计算另一个。

<!-- Height is auto-computed from width & aspect ratio -->
<img src="..." style="width: 800px;">

在 Chrome 88 中, aspect-ratio 属性可让你显式指定宽高比,从而实现类似的行为。

.square {
  aspect-ratio: 1 / 1;
}

你也可以通过 CSS4 的 not 选择器,来实现渐进增强。

.square {
  aspect-ratio: 1 / 1;
}

@supports not (aspect-ratio: 1 / 1) {
  .square {
    height: 4rem;
    width: 4rem;
  }
}

查看demo,请移步链接 (https://codepen.io/una/pen/BazyaOM )。

大幅限制链式 JavaScript 定时器

为了减少CPU和电池使用率,Chrome 从 M87 开始就在优化隐藏页面,在 M88 中,特定情况下会大幅限制隐藏页面的链式 JavaScript 计时器。

如果你在一个 setTimeout 里调用了同一个 setTimeout,这就相当于链式调用了:

let chainCount = 0;

function setTimeoutChain() {
  setTimeout(() => {
    chainCount++;
    console.log(`This is number ${chainCount} in the chain`);
    setTimeoutChain();
  }, 500);
}

在 Chrome 88 中,当以下所有的条件都成立时,你的 setTimeout 调用就会被节流限制:

  • 该页面已经隐藏 5 分钟以上(用户当前打开了其他的页面)
  • 你链式调用的计数是 5 或更多次
  • 该页面已经静音 30 秒以上
  • 未使用 WebRTC

在满足这种情况下,浏览器将每分钟检查一次定时器,你定时器里的逻辑也会在每分钟内分批处理。Chrome 官方推荐使用 setInterval 来解决这个问题。

更多信息,请移步链接(https://developer.chrome.com/blog/timer-throttling-in-chrome-88/ )。

废弃&删除的功能

页面卸载时不允许弹窗

自从Chrome 80开始,不允许在页面卸载时使用 window.open 方法来打开新页面,不过企业用户可以通过 AllowPopupsDuringPageUnload 字段来允许在页面卸载时打开弹窗。从Chrome 88开始,该字段也会被废除。

完全禁用 FTP

Chrome FTP功能的使用量较低,而且实现有bug,存在安全隐患,何况各平台都有更好用的FTP客户端,不值得继续维护。从 M72 开始,Chrome 便已着手阉割 FTP 功能,从 M86 开始,Chrome 正式开始了禁用 FTP 的过程,到 88 版本发布后,FTP 被完全禁用,禁用节奏如下:

  • Chrome 86:默认情况下,大多数用户仍启用 FTP,但对于 pre-release channels 禁用了 FTP,并且将对稳定用户的百分之一进行实验性关闭。在此版本中,用户可以使用 --enable-ftp 命令或 --enable-features=FtpProtocol 从命令行重新启用它 。
  • Chrome 87:默认情况下,百分之五十的用户将禁用 FTP 支持,但可以使用上面列出的 flag 启用 FTP 支持。
  • Chrome 88:FTP 支持被完全禁用

完全禁用 Flash

Chrome 在 83 版本对用户使用 Flash 开启了进一步提示,比如如果提示激活 Flash 插件时并导致状态更改,将会再次给予警告。

2020 年 12 月 31 日,Flash 达到了正式的生命终点,Adobe 正式停止支持该软件。1 月 12 日,Adobe 开始直接阻止 Flash 内容播放。

完全禁用混合内容下载

image.png
如上面的过程,从 M81 开始, Chrome 阻止混合内容的下载,并在各个版本开启不同文件类型的阻止,到 M88 版本,所有文件类型的混合内容下载被完全阻止。

删除 WebComponents v0

从 M80 版本开始的 WebComponents v0下线计划,到 M88 终于迎来了尾声。Chrome 不再支持Web Components v0,而是用 Web Components v1 取代它,并且 Safari、Firefox、Edge 都支持了这项改动。


image.png
关注「Alibaba F2E」
把握阿里巴巴前端新动态

相关文章
|
Web App开发
selenium之 chromedriver与chrome版本映射表(更新至v2.43)
selenium之 chromedriver与chrome版本映射表(更新至v2.43)
632 0
|
Web App开发 缓存 网络协议
chrome谷歌浏览器&firefox火狐清除dns缓存的办法
chrome谷歌浏览器&firefox火狐清除dns缓存的办法
437 0
chrome谷歌浏览器&firefox火狐清除dns缓存的办法
|
Web App开发 监控 前端开发
Chrome 96又更新了5个巨巨巨好用的功能
大家好,我是零一,收到了 Chrome 96 版本的更新推送,简单看了一下,还是更新了几个挺有趣的东西的,一起来看看到底都有啥~ 先下载 Chrome Beta 版本才能体验 Chrome 96 哈
158 0
Chrome 96又更新了5个巨巨巨好用的功能
|
Web App开发 数据采集 Python
通过爬虫中的selenium控制chrome,Firefox等浏览器自动操作获取相关信息
在pycharm中导入selenium之后,我们需要通过命令行来进行操作浏览器
通过爬虫中的selenium控制chrome,Firefox等浏览器自动操作获取相关信息
|
Web App开发 缓存 前端开发
Chrome 87 重要更新解读
该版本是多年来Chrome浏览器性能获得最大提升的一次。一起来一探究竟。
Chrome 87 重要更新解读
|
Web App开发 安全 前端开发
Chrome 86 重要更新解读
Chrome 86 在2020年10月推出了稳定版,现已全面应用于Android、Chrome OS、Linux、macOS 和 Windows等平台,我们一起来看下这次的重要更新。
Chrome 86 重要更新解读
|
Web App开发
Firefox 4.0浏览器正式版再次推迟发布
据国外媒体报道,原计划在本月月底发布的Firefox 4最终版又要推迟发布。Mozilla的火狐发布经理 Christian Legnitto表示,beta 12版本的浏览器将会被推迟发布,因为开发人员要等待火狐的漏洞被修复完毕。
930 0
|
Web App开发
chromedriver与chrome版本映射表(更新至v2.35)
看到网上基本没有最新的chromedriver与chrome的对应关系表,便兴起整理了一份如下,希望对大家有用: chromedriver版本 支持的Chrome版本 v2.
1436 0
|
Web App开发 JavaScript iOS开发
[完美]原生JS获取浏览器版本判断--支持Edge,IE,Chrome,Firefox,Opera,Safari,以及各种使用Chrome和IE混合内核的浏览器
原文:[完美]原生JS获取浏览器版本判断--支持Edge,IE,Chrome,Firefox,Opera,Safari,以及各种使用Chrome和IE混合内核的浏览器 截至自2017-08-11,支持现世已出的几乎所有PC端浏览器版本判断。
4940 0