本次预计翻译三篇文章如下:

我为什么要创建这个git仓库?通过翻译国外的web相关的技术文章来学习和跟进web发展的新思想和新技术。git仓库地址:https://github.com/yzsunlei/javascript-article-translate

从Chrome 73开始,可以结合link rel = "preload"和响应式图像,来更快地加载图像。

本文使我有机会来讨论我最喜欢的两件事:响应式图像和预加载。作为致力于开发这两块功能的人,我很高兴看到他们一起工作!

响应式概述

假设您正在300像素宽的屏幕上浏览网页,并且该页面请求了一张1500像素宽的图像。该页面就浪费了您大量的网络数据,因为您的屏幕无法使用所有这些额外分辨率进行任何操作。理想情况下,浏览器应该获取图像的一个版本,只是比你的屏幕尺寸稍微宽一些,比如说325个像素。这样可以确保图像高分辨率而又不会浪费网络数据。而且,更好的是,图像将加载得更快。响应式图像使浏览器在不同的设备上能够获取到不同的图像资源。即使不使用图像CDN为每个图像保存多个尺寸,而在srcset属性中指定它们。w值告诉浏览器每个版本的宽度。根据设备,浏览器可以选择适当的一个版本:

<img src="small.jpg" srcset="small.jpg 500w, medium.jpg 1000w, large.jpg 1500w" alt="…">

预加载概述

通过预加载,您可以在HTML中发现关键资源之前,告诉浏览器您要尽快加载的关键资源。这对于不容易发现的资源特别有用,例如样式表中包含的字体,背景图像或从脚本加载的资源。

<link rel="preload" as="image" href="important.png">

响应式图像+预加载=更快的图像加载

响应式图像和预加载在过去几年中已经就可用了,但同时缺少一些内容:无法预加载响应式图像。从Chrome 73开始,浏览器可以在srcset发现img标记之前预加载正确的响应式图像版本!

根据您网站的结构,这可能意味着显着加快图像显示速度!我们在使用JavaScript延迟加载响应图像的网站上进行了测试。预加载使图像加载速度加快了1.2秒。

所有现代浏览器均支持响应图像,而预加载图像仅在基于Chromium的浏览器中受支持。

imagesrcsetimagesizes

为了预加载响应式图像,最近向<link>元素添加了新属性:imagesrcsetimagesizes。它们与element中使用<link rel="preload">srcsetand sizes语法一起使用并匹配<img>

例如,如果您要预加载使用以下命令指定的响应图像:

<img src="wolf.jpg" srcset="wolf_400px.jpg 400w, wolf_800px.jpg 800w, wolf_1600px.jpg 1600w" sizes="50vw" alt="A rad wolf">

您可以通过将以下内容添加到HTML的<head>中来做到这一点:

<link rel="preload" as="image" href="wolf.jpg" imagesrcset="wolf_400px.jpg 400w, wolf_800px.jpg 800w, wolf_1600px.jpg 1600w" imagesizes="50vw">

这揭开了使用相同的资源选择逻辑的请求,并应用srcsetsizes的序幕。

使用案例

预加载动态注入的响应式图像

假设您要动态加载人物图像作为幻灯片的一部分,并知道将首先显示哪个图像。在这种情况下,您可能要避免在加载有问题的图像之前等待脚本,因为这会延迟用户看到它的时间。

您可以在具有动态加载的图片库的网站上检查此问题:

  • 1.在新标签页中打开此示例网站。

  • 2.按Control+Shift+J(或Command+Option+J在Mac上)按打开DevTools。

  • 3.单击网络选项卡。

  • 4.在“限制”下拉列表中

  • 5.禁用“禁用缓存”复选框。

  • 6.重新加载页面。

该瀑布流显示图像仅在浏览器完成运行脚本后才开始加载,从而给图像最初显示给用户的时间带来了不必要的延迟。

preload在此处使用帮助是因为图像会提前加载,并且在浏览器需要显示图像时可能已经存在。

该瀑布流表明,第一张图像与脚本同时开始加载,避免了不必要的延迟,从而加快了显示图像的速度。

要查看预加载的区别,您可以按照第一个示例中的步骤检查相同的动态加载的图像库,但预加载了第一张图像。

避免该问题的另一种方法是使用基于标记的轮播,并让浏览器的预加载器选择所需的资源。但是,这种方法可能并不总是实用的。(例如,如果您正在复用现有的不基于标记的组件。)

使用图片集预加载背景图片

如果您针对不同的屏幕分辨率使用不同的背景图像,则可以使用以下image-set语法在CSS中指定它们。然后,浏览器可以根据屏幕的DPR选择显示哪一个。

background-image: image-set( "cat.png" 1x, "cat-2x.png" 2x);

上面的语法忽略了以下事实:在基于Chromium和基于WebKit的浏览器中,此功能需要浏览器的前缀。如果您打算使用此功能,则应考虑使用Autoprefixer来自动处理该问题。

CSS背景图片的问题在于,只有在浏览器下载并处理了页面中的所有CSS后,浏览器才会发现它们<head>,这可能是很多CSS…

您可以在带有响应背景图片的示例网站上检查此问题。

在此示例中,直到完全下载CSS后才开始图像下载,从而导致图像显示产生不必要的延迟。

响应式图像预加载提供了一种简单且无漏洞的方法来更快地加载这些图像。

<link rel=preload href=cat.png as=image imagesrcset="cat.png 1x, cat-2x.png 2x">

您可以在预加载的响应式背景图像检查前面的示例的效果。

此处,图像和CSS同时开始下载,避免了延迟并加快了图像的加载速度。

预加载响应图像的实践

在理论上预加载您的响应式图像可以加快它们的速度,但是实际上它有什么作用?

为了回答这个问题,我创建了一个演示PWA商店的两个副本:一个不预加载图像,另一个预加载一些图像。由于该站点使用JavaScript懒加载图像,因此可能会受益于预加载初始视口中的图像。

这给了我以下结果:无预加载和图像预加载。从原始数字来看,我们看到“开始渲染”保持不变,“速度指数”略有改善(273毫秒,因为图像到达速度更快,但并没有占用很大的像素区域),但是真正的指标可以捕捉到差异是最后绘制的主题图像指标,提高了1.2秒。

[技术翻译]预加载响应式图像,从Chrome 73开始实现的更多相关文章

  1. seo网页加速技术,预加载 DNS Prefetching 详解

    seo网页加速技术,预加载 DNS Prefetching 详解 DNS Prefetching 是什么 : DNS 是什么-- Domain Name System,域名系统,作为域名和IP地址相互 ...

  2. Javascript图片预加载详解

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  3. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  4. CSS和JavaScript以及Ajax实现预加载图片的方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画 廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发 ...

  5. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法(转)

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  6. Javascript图片预加载详解 分类: JavaScript HTML+CSS 2015-05-29 11:01 768人阅读 评论(0) 收藏

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  7. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  8. 页面资源预加载(Link prefetch)功能加速你的页面加载速度

    有了浏览器缓存,为何还需要预加载? 用户可能是第一次访问网站,此时还无缓存 用户可能清空了缓存 缓存可能已经过期,资源将重新加载 用户访问的缓存文件可能不是最新的,需要重新加载 页面资源预加载/预读取 ...

  9. HTML5的页面资源预加载技术(Link prefetch)加速页面加载

    不管是浏览器的开发者还是普通web应用的开发者,他们都在做一个共同的努力:让Web浏览有更快的速度感觉.有很多已知的技术都可以让你的网站速度变得更快:使用CSS sprites,使用图片优化工具,使用 ...

随机推荐

  1. python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图

    python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图 # coding=utf-8 from openpyxl import load_workbook ...

  2. py文件单独调试django ORM的配置

    1.新建一个py文件 2.代码环境搭建 import os if __name__ != '__main__': exit() # 加载django项目的配置信息 os.environ.setdefa ...

  3. Spring Cloud Ribbon 客户端负载均衡 4.3

      在分布式架构中,服务器端负载均衡通常是由Nginx实现分发请求的,而客户端的同一个实例部署在多个应用上时,也需要实现负载均衡.那么Spring Cloud中是否提供了这种负载均衡的功能呢?答案是肯 ...

  4. C# log4net 配置及使用详解--日志保存到文件和Access(转)

    按语: 最近项目要求选用Access数据库,但日志管理采用log4net,但保存到数据库一直没有成功,后按照如下配置在程序退出时可以成功保存. 开始新建文件应用log4net.dll  ,重新编译就报 ...

  5. 【线段树】HDU 1166 敌兵布阵

    这道题目是线段树里面最基础的单点更新问题. 设计的知识点包括线段树的单点更新和区间查询. 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 G++ ...

  6. 关于Js异常

    一.Javascript的异常处理机制 当javascript代码中出现错误的时候,js引擎就会根据js的调用栈逐级寻找对应的catch,如果没有找到相应的catch handler或catch ha ...

  7. Sequelize模型定义

    定义 定义模型与表之间的映射,使用 define 方法. Sequelize 会自动增加 createdAt 和 updated 属性,这样能知道一个实例的创建时间和最终修改时间.如果不想自动生成,可 ...

  8. vue-cli3.0和element-ui及axios的安装使用

    一.利用vue-cli3快速搭建vue项目 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.有三个组件: CLI:@vue/cli 全局安装的 npm 包,提供了终端里的vue命令( ...

  9. 14、OpenCV实现图像的空间滤波——图像锐化及边缘检测

    1.图像锐化理论基础 1.锐化的概念 图像锐化的目的是使模糊的图像变得清晰起来,主要用于增强图像的灰度跳变部分,这一点与图像平滑对灰度跳变的抑制正好相反.而且从算子可以看出来,平滑是基于对图像领域的加 ...

  10. 【GStreamer开发】GStreamer基础教程03——动态pipeline

    本教程介绍pipeline的一种新的创建方式--在运行中创建,而不是在运行前一次性的创建结束. 介绍 在这篇教程里的pipeline并非在运行前就全部创建结束的.放松一下,这样做没有任何问题.如果我们 ...