Chrome 88 重要更新解读-阿里云开发者社区

开发者社区> AlibabaF2E> 正文
登录阅读全文

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」
把握阿里巴巴前端新动态

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
AlibabaF2E
使用钉钉扫一扫加入圈子
+ 订阅

阿里经济体前端技术最新内容汇聚在此,由阿里经济体前端委员会官方运营。我们的愿景是建立全球一流的前端团队,链接商业,让数字世界触手可及是我们的使命。阿里经济体前端委员会致力于加强技术前瞻性、推进集体成长、提升国际影响力。同时我们运营着阿里经济体前端的官方公众号:Alibaba F2E,欢迎关注。

官方博客