Sie haben JavaScript deaktiviert. Vermutlich sind Sie ein Kollege und wollen nur sehen, ob meine Website auch ohne JavaScript funktioniert.
Andernfalls: Bitte aktivieren Sie JavaScript!
Hinweis:
Dieser Artikel ist älter als 18 Monate / wurde seit 18 Monaten nicht aktualisiert. Dies kann (muss aber nicht) dazu führen, dass der Artikel, und / oder darin beschriebene Techniken, nicht mehr aktuell sind. Bitte berücksichtigen Sie diesen Hinweis bei der Lektüre.
Mein jüngstes Projekt – ein sog. One Pager – habe ich (auch) dazu benutzt, alle verfügbaren Techniken zur On-Page-Optimierung einzusetzen. Zweck der Übung: Optimierung der User Experience (UX), und möglichst gute Sichtbarkeit in Suchmaschinen (v.a. natürlich Google).
Achtung! Es folgt viel Fachchinesisch! TL;DR
Die Forderung, eine optisch ansprechende Site zu gestalten, führte zwangsläufig zur Verwendung möglichst vieler, und möglichst großformatiger Bilder. Dies wurde realisiert durch eine Slideshow mit automatischem Durchlauf. Zum Einsatz kam Slick. Ich habe dieses Tool hier schon früher beschrieben. Die in der Slideshow präsentierten Fotos – derzeit 10, jederzeit erweiterbar – würden ohne Optimierung bereits zu einer Seitengröße von mehreren MB führen. Um die Seite schnell zu laden – auch und vor allem im Mobilfunknetz – wurden also folgende Optimierungsschritte durchgeführt:
werden dankenswerterweise zur Verfügung gestellt von terra-hd:
Die Bilder liegen leider nur im jpeg-Format vor. Dafür aber in verschiedenen Auflösungen. Ich habe für Desktop 1200 px-breite Bilder gewählt, und für Smartphones 512 px.
Zur Präsentation der 4 Live-Webcam-Bilder verwende ich einen manuellen CSS-only-Slider. Der Bildwechsel erfolgt durch Ziehen mit der Maus bzw. Wischen auf Touchscreens. Die Technik habe ich hier beschrieben, mit allen erforderlichen Code-Snippets.
Als zusätzlichen Komfort kann der Bildwechsel nicht nur durch Ziehen bzw. Wischen erfolgen, sonden auch durch einen Klick / Tipp ins Bild.
<div id= "container" class="my-gallery">
<div class="slider2" tabindex="0">
<img src="Pfad_zum_Bild_1" loading="lazy" >
<img src="Pfad_zum_Bild_2" loading="lazy" >
…
</div>
</div>
if (document.querySelector(".slider2")) {
$(".my-gallery").click(function () {
var matched = $(".slider2 img");
var width = $("#container").width();
var leftPos = $('.slider2').scrollLeft();
dir = sessionStorage.getItem("direction");
if (leftPos >= width * (matched.length - 1)) {
var dir = "left";
sessionStorage.setItem("direction","left");
}
if (leftPos == 0) {
var dir = "right";
sessionStorage.setItem("direction","right");
}
if (dir == "left") {
$( ".slider2" ).scrollLeft( leftPos - width );
} else {
$( ".slider2" ).scrollLeft( leftPos + width );
}
});
}
Hinweis: Der obige JavaScript-Code erfordert jQuery
Außer bei Slick muss Lazy-Loading manuell eingefügt werden. Zum Glück ist das heute ganz einfach. Das Attribut loading="lazy" im img-Tag weist den Browser an, das jeweilig Bild erst bei Bedarf zu laden. Auch Lazy-Loading wird von allen modernen Browsern unterstützt.
Dass sich autoplay für Videos verbietet, versteht sich von selbst. Moderne Browser verhindern das ohnehin, und das zu Recht. Aber Lazy-Loading? Ja, auch das kann Sinn machen. Die default-Einstellung der Browser führt nämlich dazu, dass einige hundert KB des Videos beim Seitenaufruf vorgeladen werden, damit das Video beim Klick auf den Play-Button sofort startet.
Bei einer schnellen Internetanbindung kann man auf das Preloading verzichten. Und bei einer langsamen Verbindung, z. B. im Mobilfunknetz, sollte man das sogar, um den Seitenaufbau nicht zu verzögern, und das Datenvolumen für das Preloading einzusparen, wenn der Besucher das Video nicht startet.
Dieses defaultmäßige Preloading kann man überschreiben mit dem Attribut preload="none" im video-Tag.
Es gibt im Responsive Design verschiedene Techniken, um das verwendete Gerät (PC, Smartphone, Tablet) zu erkennen, und die jeweils passenden Inhalte bereitzustellen. Diese Techniken basieren auf HTML, CSS oder JavaScript.
Ich verwende eine PHP-Klasse, um bereits serverseitig das Gerät des Users zu erkennen, und nur die jeweils benötigten Inhalte auszuliefern: mobiledetect. Diese Methode ist universell einsetzbar, nicht nur, um Bilder in der richtigen Größe auszuliefern, sondern beispielsweise auch um Preloads oder JavaScript nur geräteabhängig einzubinden.
<?php
if (file_exists("Mobile_Detect.php")) {
require_once "Mobile_Detect.php";
$detect = new Mobile_Detect;
}
…
if ($detect->isMobile() && !$detect->isTablet()){
echo '<link rel="preload" href="img/O37A0601_600.webp" as="image" type="image/webp" >';
} else {
echo '<link rel="preload" href="img/O37A0601_1100.webp" as="image" type="image/webp" >
';
}
?>
Icons sind zwar zumeist nur wenige kB schwer, aber jedes Icon erfordert einen zusätzlichen HTTP request, und damit Ladezeit. ¹)
Es macht daher Sinn, Icons base64 zu kodieren, und inline einzubinden. Der HTML-Tag sieht dann beispielsweise so aus:
<img src="" alt="zum Seitenanfang" height="30" width="30">
anstatt
<img src = "icon.png" width="30" height="30">
Hier ein Online-Konvertierungs-Tool um den base64-Code zu erstellen.
¹) Die Anzahl von HTTP requests spielt durch die zunehmende Verfügbarkeit von HTTP/2 keine entscheidende Rolle mehr.
Die On-Page-Optimierung ist geglückt ✔︎
Artikeltexte und Code-Snippets: Creative Commons CC BY-SA 4.0
Medien (Bilder, Videos, Audios) sind evtl. urheberrechtlich geschützt.
Über Ihren Kommentar zu diesem Artikel freue ich mich.
Wenn Sie aber Fragen haben, und eine Antwort erwarten, nutzen Sie bitte das Supportforum! Die Nutzung des Forums ist auch ohne Registrierung möglich.