Heim  >  Artikel  >  Backend-Entwicklung  >  So testen Sie die Seitenladezeit mit PHP WebDriver

So testen Sie die Seitenladezeit mit PHP WebDriver

PHPz
PHPzOriginal
2023-06-15 22:06:001555Durchsuche

Angesichts der anhaltenden Beliebtheit des Internets ist die Seitenladezeit als wichtiger Indikator für die Benutzererfahrung von großer Bedeutung für die Website-Optimierung und Leistungsoptimierung. Während des Testprozesses wird die genaue Messung der Seitenladezeit zu einem wichtigen Thema. In diesem Artikel wird erläutert, wie Sie mit PHP WebDriver die Seitenladezeit testen.

1. Einführung in PHP WebDriver

PHP WebDriver ist ein PHP-Entwicklungstool, das auf Selenium WebDriver basiert. Es steuert den Browser, um Seitenvorgänge auszuführen, indem er den zugrunde liegenden Treiber des Browsers aufruft. Mit PHP WebDriver können Sie automatisierte Tests, Crawling und andere Funktionen von Webseiten implementieren.

2. Testmethode für die Seitenladezeit

Bevor wir die Seitenladezeit testen, müssen wir mehrere Konzepte verstehen:

  • Erste Malzeit: bezieht sich auf den Zeitpunkt, zu dem der Browser mit dem Rendern der Seite beginnt das erste Pixel erscheint.
  • First Contentful Paint: bezieht sich auf den Zeitpunkt, an dem der erste Stapel sinnvoller Inhalte auf der Seite erscheint.
  • Erster interaktiver Zeitpunkt: bezieht sich auf den Zeitpunkt, zu dem das Hauptskript auf der Seite geladen wurde und der Benutzer mit der Interaktion beginnen kann.
  • Seitenladezeit: bezieht sich auf die Zeit, in der alle Ressourcen auf der Seite vollständig geladen sind und das Skript ausgeführt wird.

Basierend auf den oben genannten Konzepten können die folgenden Tests durchgeführt werden:

  1. Erster Paint-Zeittest

Wenn der Browser mit dem Zeichnen der Seite beginnt, können wir zum Abrufen den „First-Paint“ in der Performance-Timing-API verwenden Beim ersten Rendern lautet der Code wie folgt:

$driver->get('http://www.baidu.com');
$performance = $driver->executeScript('return window.performance.timing');
$firstPaint = $performance['responseStart'] - $performance['navigationStart'];
echo "First Paint Time: " . $firstPaint . "ms
";
  1. Erster Contentful Paint-Test

Aufgrund der Rolle des Browser-Cache ist das erste Rendering möglicherweise nicht vollständig, daher benötigen wir eine genauere Methode zum Testen von First Contentful Paint (FCP).

Erhalten Sie den Zeitstempel der letzten Inhaltsänderungen über die Observer-API des Browsers, um die Funktion zum Messen des FCP zu erreichen. Der Beispielcode lautet wie folgt:

$driver->get('http://www.baidu.com');
$driver->executeScript('function observerCallback(entries) {
  entries.forEach(entry => {
      if(entry.entryType == "paint" && entry.name == "first-contentful-paint") {
        console.log(entry.startTime);
        return entry.startTime;
      }
  });
}
var observer = new PerformanceObserver(observerCallback);
observer.observe({entryTypes: ["paint"]});');
  1. Erster interaktiver Zeittest

Für die erste interaktive Zeit kann er durch Überwachung getestet werden Das DOMContentLoaded-Ereignis lautet wie folgt:

$driver->get('http://www.baidu.com');
$driver->executeScript('function ti() {
    var ti = window.performance.timing.domContentLoadedEventEnd - window.performance.timing.navigationStart;
    console.log(ti);
    return ti;
}
return {ti: ti()};');
  1. Seitenladezeittest

Die vollständige Ladezeit der Seite kann über die Navigations-Timing-API ermittelt werden. Der Beispielcode lautet wie folgt:

$driver->get('http://www.baidu.com');
$performance = $driver->executeScript('return window.performance.timing');
$pageLoadTime = $performance['loadEventEnd'] - $performance['navigationStart'];
echo "Page Load Time: " . $pageLoadTime . "ms
";

三, Fazit

Die Verwendung von PHP WebDriver zum Testen der Seitenladezeit kann uns helfen, die Seitenleistung besser zu verstehen und wichtige Hinweise für die Optimierung der Website zu liefern. In diesem Artikel wird erläutert, wie Sie den PHP WebDriver zum Testen der Seitenladezeit verwenden. Leser können ihn entsprechend ihrer tatsächlichen Situation implementieren.

Das obige ist der detaillierte Inhalt vonSo testen Sie die Seitenladezeit mit PHP WebDriver. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn