[关闭]
@qinyun 2018-09-05T18:27:25.000000Z 字数 1961 阅读 2418

兼容刘海屏!Chrome 69正式发布

未分类


2008年9月2日,Chrome浏览器诞生,今天,Chrome 69正式发布,从诞生到占据浏览器的半壁江山,Google用了10年时间。从第一次发布之日起到现在,Chrome发生了很多变化,但Chrome为现代Web应用程序构建坚实基础的目标却一直没有变!

在Chrome 69中,新添加了对以下内容的支持:

更多内容请戳:https://developers.google.com/web/updates/2018/09/nic69#more

CSS Scroll Snap

开发者可以通过CSS Scroll Snap来创建流畅平滑的滚动体验。开发者声明目标滚动位置,告诉浏览器在执行完滚动操作后停在哪个位置。这对于某些场景非常有用,比如在进行图像轮播或分页时,可以让用户滚动到指定位置。

视频链接:https://developers.google.com/web/updates/images/2018/07/css-scroll-snap/gallery-page.mp4

对于图像轮播,可以为滚动容器添加scroll-snap-type: x mandatory;,同时为每个图像添加snap-align: center;。然后,当用户进行滚动操作时,每个图像将平滑地滚动到目标位置。

  1. #gallery {
  2. scroll-snap-type: x mandatory;
  3. overflow-x: scroll;
  4. display: flex;
  5. }
  6. #gallery img {
  7. scroll-snap-align: center;

兼容刘海屏

随着越来越多的手机使用刘海屏,Chrome浏览器会为页面腾出一些额外的空间,这样内容就不会被凹口遮住。

但如果你想要使用凹口空间该怎么办?

使用CSS环境变量和viewport-fit元标记就可以实现你的目的。例如,要让浏览器扩展到凹口区域,可以在viewport元标记中将viewport-fit属性设置为cover。

  1. <meta name='viewport' content='initial-scale=1, viewport-fit=cover'>

然后,你就可以使用safe-area-inset-* CSS环境变量来布局内容。

  1. .content {
  2. padding: 16px;
  3. padding-left: env(safe-area-inset-left);
  4. padding-right: env(safe-area-inset-right);
  5. }

Web Locks API

Web Locks API让开发者可以异步获取锁,在执行任务期间保持锁,然后释放它。在保持锁的同时,origin中的其他脚本无法获取相同的锁,从而有助于协调共享资源的使用。

例如,如果在多个选项卡中运行的Web应用程序想要确保同时只有一个选项卡可以进行网络同步,那么同步代码就需要尝试获取一个叫作network_sync_lock的锁。

  1. navigator.locks.request('network_sync_lock', async lock => {
  2. // 获取锁
  3. await do_something();
  4. await do_something_else();
  5. // 锁将被释放
  6. });

第一个获取到锁的选项卡将开始网络同步。如果另一个选项卡尝试获取相同的锁,它需要排队。锁被释放后,队列中的下一个请求将获得锁。

MDN提供了一个很棒的Web Locks入门教程,进行了更深入的解释,并提供了大量示例(https://developer.mozilla.org/en-US/docs/Web/API/Web_Locks_API)。

以上这些只是针对开发人员的一些变化,当然还有其他更多特性:

英文原文

https://developers.google.com/web/updates/2018/09/nic69

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注