Heim >Web-Frontend >Front-End-Fragen und Antworten >10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

青灯夜游
青灯夜游nach vorne
2020-10-26 17:47:032559Durchsuche

10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

In diesem Artikel stellen wir hauptsächlich 10 Möglichkeiten vor, um die Leistung Ihrer Website schnell zu verbessern. Kommen wir ohne weiteres zur Sache. 10种快速提高网站性能的方法,你只需5分钟内就可以将它应用到你的网站上,废话不多说,让我们进入正题吧。

1. 文件压缩

文件压缩,可以减少网络传输的字节数。有几种压缩算法。Gzip是最流行的,但是对于Brotli,你可以使用一种更新的、甚至更好的压缩算法。如果想检查您的服务器是否支持Brotli,可以使用 Brotli.pro。

如果你的服务器不支持Brotli,则可以按照以下简单指南进行安装:

2. 图像压缩

未压缩的图像是一个巨大的潜在性能瓶颈。如果在将图像提供给用户之前没有压缩它们,那么就会传输不必要的字节。有几个有用的工具可以用于快速压缩图像且不损失可见质量。我主要使用Imagemin。它支持许多图像格式,您w你以将其用作命令行界面或npm模块。

imagemin img/* --out-dir=dist/images

你还可以 将npm 引入到项目里,使用imagemin-mozjpeg,可以将JPEG图像压缩到原有的60%

const imagemin = require('imagemin');
const imageminMozjpeg = require('imagemin-mozjpeg');

(async() => {
  const files = await imagemin(
      ['img/*.jpg'],
      {
        destination: 'dist/img',
        plugins: [
          imageminMozjpeg({quality: 60}),
        ]
      }
  );
  console.log(files);
})();

就我而言,它将文件大小从4MB减小到100kB:

10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

3.图像格式

使用现代图像格式可以真正提高性能。 WebP 图像比 JPEG 和 PNG 小,通常小25%-35%WebP 也被浏览器广泛支持。

我们使用imagemin npm 包并为其添加WebP插件。 以下代码将我的图像的WebP版本输出到dist文件夹中。

const imagemin = require('imagemin');
const imageminWebp = require('imagemin-webp');

(async() => {
  const files = await imagemin(
      ['img/*.jpg'],
      {
        destination: 'dist/img',
        plugins: [
          imageminWebp({quality: 50})
        ]
      }
  );
  console.log(files);
})();

我们再次看一下文件大小:

10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

结果表明,与原始图像相比,文件大小减少了98%,与压缩的 JPG 文件相比,WebP 对图像的压缩效果更加明显,WebP版本比压缩的JPEG版本小43%

4.图像延迟加载

延迟加载图像是一种稍后而不是提前加载屏幕外图像的技术。当解析器遇到正确加载的图像时,会减慢初始页面加载速度。通过延迟加载,可以加快这个过程并在以后加载图像。使用lazysize很容易做到这一点。使用lazysize脚本和浏览器对loading属性的支持,你可以这样优化:

<img  alt="10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)" >

改成:

<img  alt="10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)" >

该库会处理其余的工作,你可以使用浏览器验证这一点。打开你的网站,找到你的图像标签。如果类从lazyload更改为lazyloaded

1. Dateikomprimierung

Dateikomprimierung kann die Anzahl der über das Netzwerk übertragenen Bytes reduzieren. Es gibt mehrere Komprimierungsalgorithmen. Gzip ist am beliebtesten, aber mit Brotli können Sie einen neueren und noch besseren Komprimierungsalgorithmus verwenden. Wenn Sie überprüfen möchten, ob Ihr Server Brotli unterstützt, können Sie Brotli.pro verwenden.

Wenn Ihr Server Brotli nicht unterstützt, können Sie es installieren, indem Sie dieser einfachen Anleitung folgen:

    Nginx unter Linux
  • Apache
  • NodeJs - Express
  • 2. Bildkomprimierung
  • Unkomprimierte Bilder stellen einen großen potenziellen Leistungsengpass dar. Wenn Bilder vor der Bereitstellung an den Benutzer nicht komprimiert werden, werden unnötige Bytes übertragen. Es gibt mehrere nützliche Tools zum schnellen Komprimieren von Bildern, ohne dass die sichtbare Qualität verloren geht. Ich verwende hauptsächlich Imagemin. Es unterstützt viele Bildformate und Sie können es als Befehlszeilenschnittstelle oder als npm-Modul verwenden.
var criticalcss = require("criticalcss");

var request = require('request');
var path = require( 'path' );
var criticalcss = require("criticalcss");
var fs = require('fs');
var tmpDir = require('os').tmpdir();

var cssUrl = 'https://web.dev/app.css';
var cssPath = path.join( tmpDir, 'app.css' );
request(cssUrl).pipe(fs.createWriteStream(cssPath)).on('close', function() {
  criticalcss.getRules(cssPath, function(err, output) {
    if (err) {
      throw new Error(err);
    } else {
      criticalcss.findCritical("https://web.dev/", { rules: JSON.parse(output) }, function(err, output) {
        if (err) {
          throw new Error(err);
        } else {
          console.log(output);
          // save this to a file for step 2
        }
      });
    }
  });
});

Sie können auch npm in das Projekt einführen und imagemin-mozjpeg verwenden, um JPEG-Bilder auf das Original 60 % zu komprimieren:

  <style>
  body {...}
  /* ... rest of the critical CSS */
  </style>

Nur ich Mit anderen Worten, es reduziert die Dateigröße von 4MB auf 100kB:10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

3. Bildformate

Die Verwendung moderner Bildformate kann die Leistung erheblich verbessern. WebP-Bilder sind kleiner als JPEG und PNG, normalerweise 25–35 % kleiner. WebP wird auch von Browsern weitgehend unterstützt.

Wir verwenden das Imagemin-NPM-Paket und fügen das WebP-Plugin hinzu. Der folgende Code gibt die WebP-Version meines Bildes in den Ordner dist aus.

<link>
<noscript><link></noscript>

Schauen wir uns noch einmal die Dateigröße an:

10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen)

Die Ergebnisse zeigen, dass die Dateigröße im Vergleich zum Originalbild um 98 % reduziert ist. Im Vergleich zur komprimierten JPG-Datei hat WebP einen deutlicheren Komprimierungseffekt auf dem Bild. Die Version ist 43 % kleiner als die komprimierte JPEG-Version.

4. Lazy Loading von Bildern

🎜Lazy Loading von Bildern ist eine Technik, bei der Bilder außerhalb des Bildschirms später statt früher geladen werden. Wenn der Parser auf ein ordnungsgemäß geladenes Bild stößt, verlangsamt er das anfängliche Laden der Seite. Durch verzögertes Laden können Sie den Vorgang beschleunigen und das Bild später laden. Mit lazysize geht das ganz einfach. Mithilfe des Skripts lazysize und der Browserunterstützung für das Attribut loading können Sie Folgendes optimieren: 🎜
<script></script>
🎜 zu: 🎜
<script></script>
🎜Die Bibliothek erledigt den Rest, Sie können ihn verwenden Ihren Browser, um dies zu überprüfen. Öffnen Sie Ihre Website und suchen Sie nach Ihrem Bild-Tag. Es funktioniert, wenn die Klasse von lazyload in lazyloaded geändert wird. 🎜🎜5. HTTP-Header zwischenspeichern 🎜🎜Caching ist eine schnelle Möglichkeit, die Geschwindigkeit der Website zu erhöhen. Es reduziert die Seitenladezeit für Besucher. Wir können den Browser anweisen, Dateien zu einem bestimmten Zeitpunkt zwischenzuspeichern. Wenn Sie über einige Hintergrundkenntnisse verfügen, ist die Konfiguration der Caching-Methode nicht schwierig. 🎜🎜Wir können die folgende API zum Caching verwenden: 🎜🎜🎜🎜Cache-Control🎜🎜🎜🎜ETag🎜🎜🎜🎜Last-Modified🎜🎜🎜🎜6. Inline-kritisches CSS🎜🎜CSS blockiert 🎜’s, Dies bedeutet, dass der Browser alle CSS-Dateien herunterladen und verarbeiten muss, bevor er die Pixel zeichnen kann. Dieser Prozess kann durch Inlining von kritischem CSS erheblich beschleunigt werden. Wir können dies mit den folgenden Schritten tun: 🎜🎜 Kritisches CSS identifizieren 🎜🎜 Wenn Sie nicht wissen, was Ihr kritisches CSS ist, können Sie Critcal, CriticalCSS oder Penthouse verwenden. Alle diese Bibliotheken extrahieren CSS aus HTML-Dateien, die in einem bestimmten Ansichtsfenster sichtbar sind. 🎜🎜criticalCSS Beispiele sind wie folgt: 🎜
 <link>
🎜Inline kritisches CSS🎜🎜Der HTML-Parser trifft auf das Style-Tag und verarbeitet das kritische CSS sofort. 🎜
 <link>
🎜Nacheilendes nicht kritisches CSS🎜🎜Nicht kritisches CSS muss nicht sofort verarbeitet werden. Der Browser kann es nach dem Onload-Ereignis laden, sodass der Benutzer nicht warten muss. 🎜
<link>
<noscript><link></noscript>

7. JavaScript 异步/延迟加载/延迟加载

HTML 也是阻塞渲染,浏览器必须等待 JS 执行后才能完成对HTML的解析。但是我们可以告诉浏览器等待JavaScript执行。

异步加载JavaScript

使用属性async,可以告诉浏览器异步加载脚本。

<script></script>

延迟JavaScript

defer属性告诉浏览器在 HTML 解析器解析完文档之后运行脚本,但在事件发生之前,DOMContentLoaded会被触发。

<script></script>

重复排序内联的脚本

内联脚本立即执行,浏览器对其进行解析。 因此,您可以将它们放在HTML的末尾,紧接在body标记之前。

8.使用资源提示优化性能

HTML5的资源提示(Resource Hints)可以简单地理解为预加载,浏览器根据开发者提供的后续资源的提示进行有选择性的加载和优化。“有选择性”这一项是必须的且极其重要的,也是有别早先替代方案的重点,因为很多情况下,预加载会受到所分配到的计算资源以及带宽资源的限制,浏览器有权放弃那些成本较高的加载项。

资源提示帮助开发人员告诉浏览器稍后可能加载的页面。该规范定义了四种原语

  • preconnect
  • dns-prefetch
  • prefetch
  • prerender

此外,对于资源提示,我们使用了链接属性的preload关键字。

preconnect

预链接, 使用方法如下:

 <link>

我们访问一个站点时,简单来说,都会经过以下的步骤:

  1. DNS 解析
  2. TCP 握手
  3. 如果为 Https 站点,会进行TLS握手

使用preconnect后,浏览器会针对特定的域名,提前初始化链接(执行上述三个步骤),节省了我们访问第三方资源的耗时。需要注意的是,我们一定要确保preconnect的站点是网页必需的,否则会浪费浏览器、网络资源。

DNS Prefetch

DNS 预解析, 这个大多数人都知道,用法也很简单:

 <link>

DN S解析,简单来说就是把域名转化为ip地址。我们在网页里使用域名请求其他资源的时候,都会先被转化为ip地址,再发起链接。dns-prefeth使得转化工作提前进行了,缩短了请求资源的耗时。

什么时候使用呢?当我们页面中使用了其他域名的资源时,比如我们的静态资源都放在cdn上,那么我们可以对cdn的域名进行预解析。浏览器的支持情况也不错。

prefetch

预拉取, 使用方法如下:

<link>
<link>
<link>
<link>
<link>

link标签里的as参数可以有以下取值:

audio: 音频文件
video: 视频文件  
Track: 网络视频文本轨道 
script: javascript文件
style: css样式文件
font: 字体文件   
image: 图片   
fetch: XHR、Fetch请求
worker: Web workers
embed: 多媒体<embed>请求 
object:  多媒体<object>请求
document: 网页</object></embed>

预拉取用于标识从当前网站跳转到下一个网站可能需要的资源,以及本网站应该获取的资源。这样可以在将来浏览器请求资源时提供更快的响应。

如果正确使用了预拉取,那么用户在从当前页面前往下一个页面时,可以很快得到响应。但是如果错误地使用了预拉取,那么浏览器就会下载额外不需要的资源,影响页面性能,并且造成网络资源浪费。

这里需要注意的是,使用了prefetch,资源仅仅被提前下载,下载后不会有任何操作,比如解析资源。

prerender

预渲染,使用方法如下:

<link>

prerender比prefetch更进一步。不仅仅会下载对应的资源,还会对资源进行解析。解析过程中,如果需要其他的资源,可能会直接下载这些资源。这样,用户在从当前页面跳转到目标页面时,浏览器可以更快的响应。

preload

<link>
<link>

注意preload需要写上正确的as属性,才能正常工作喔(prefetch不需要)。但是它们有什么区别呢?

  • preload 是用于预加载当前页的资源,浏览器会优先加载它们
  • prefetch 是用于预加载后续导航使用的资源,浏览器也会加载它们,但优先级不高

9. 固定好你的谷歌字体

Google字体很棒,它们提供优质的服务,并被广泛使用。 如果你不想自己托管字体,那么Google字体是一个不错的选择。 你需要的是学习如何引用它们,哈里·罗伯茨(Harry Roberts)写了一篇有关《The Fastest Google Fonts》的出色深度文章。 强烈建议你阅读它。

如果你快速取用,那么可以使用下面集成片段的谷歌字体:

<link>
<link>
<link>
<noscript><link></noscript>

10. 使用 service worker  缓存资源

service worker是浏览器在后台运行的脚本。缓存可能是最常用的特性,也是你应该使用的特性。我认为这不是一个选择的问题。通过使用 service worker实现缓存,可以使 用户 与站点的交互更快,并且即使用户不在线也可以访问站点。

总结

在这篇文章中,展示了 10 种快速的网络性能,你可以在5分钟内应用到你的网站,以提高你的网站速度。

感谢大家的观看与支持,我们下期再见,不要忘了三连哦。

原文:https://dev.to/marcradziwill/10-web-performance-quick-wins-you-can-and-should-apply-in-under-5-minutes-1dj2

作者:Marc

更多编程相关知识,请访问:编程入门!!

Das obige ist der detaillierte Inhalt von10 Möglichkeiten zur schnellen Optimierung der Webleistung (Teilen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen