Neu wie kann ich Bilder im Content den Lazy Load effekt zuweisen ?

Conny

Sehr aktives Mitglied
7. September 2009
521
49
Wenn man z.B. auf der Startseite viele Bilder hat (Inhalte -> eigene Seiten), so möchte ich daß die Bilder auch "Lazy Load" Effekt haben.
Wie muss ich diese Bilder einfügen.
HTML:
<img
 alt="mein Testbild"
 data-src="media/image/product/1206/md/bild.jpg" 
data-id="1"
 style="max-height: 344px;"
 src="media/image/product/1206/md/bild.jpg"
>

Reicht es dafür das "data-src" Attribut zu füllen?
 

martinwolf

Offizieller Servicepartner
SPBanner
6. September 2012
3.369
245
Okay, mein Fehler. Bin davon ausgegangen, dass JTL das lazyLoad für sämtliche Bilder triggert. Dem ist jedoch nicht so, stattdessen greift es nur bei Bildern innerhalb der Artikellisten.
 

Conny

Sehr aktives Mitglied
7. September 2009
521
49
Ok. Aber das kann man doch bestimmt auch nachprogrammieren, dass es so funktioniert wie in den Artikellisten.
Muss ich da noch ein js einbinden ?
 

css-umsetzung

Offizieller Servicepartner
SPBanner
6. Juli 2011
5.204
995
Berlin
Theoretisch ja, vorsichtshalber solltest du den Bildern noch eine Klasse geben, damit da nichts durcheinander kommt.
Als Klasse verwende ich hier jetzt mal lazyloader

Code:
$(function() {
  $("img.lazyloader").lazy(($(window).height() / 2), function() {
   // hier blabla wenn in der Zwischenzeit Schmetterlinge über den Bildschirm fliegen sollen
  });
});
 

martinwolf

Offizieller Servicepartner
SPBanner
6. September 2012
3.369
245
Ich würde den Selektor anpassen, sodass nur Bilder die noch KEIN src-Attribut haben, berücksichtigt werden.
Code:
$(function() {
  $("img:not([src])").lazy(($(window).height() / 2), function() {
   // hier blabla wenn in der Zwischenzeit Schmetterlinge über den Bildschirm fliegen sollen
  });
});
 

Conny

Sehr aktives Mitglied
7. September 2009
521
49
Hi, danke für die Hilfe

@martinwolf - Wie soll ich das Bild dann einbinden ?
HTML:
       <img alt="mein Testbild" class="lazy img-responsive" src="media/image/product/1206/md/bild.jpg" />

Und bei dem Script kann ich den Spinner angeben - wäre das so richtig?
HTML:
$(function() {
  $("img:not([src])").lazy(($(window).height() / 2), function() {
   // hier blabla wenn in der Zwischenzeit Schmetterlinge über den Bildschirm fliegen sollen
   <img src="preloader.gif />
  });
});
 

martinwolf

Offizieller Servicepartner
SPBanner
6. September 2012
3.369
245
@Conny:

Das Bild benötigt anstelle des src-Attributes ein data-src. Klasse brauchst du keine bestimmte zuweisen, da reicht img-responsive, damit das Bild responsive skaliert. Die Funktion triggert für alle Bilder die KEIN src-Attribut haben.

HTML:
<img alt="mein Testbild" data-src="media/image/product/1206/md/bild.jpg" />

Die JS Funktion kann auf ein Minimum reduziert werden:

JavaScript:
$(function() {
    $("img:not([src])").lazy();
});

Anders als von CSS-Umsetzung kommentiert, wird
// hier blabla wenn in der Zwischenzeit Schmetterlinge über den Bildschirm fliegen sollen
nicht während des Ladens ausgeführt, sondern danach. Es ist ein callback. Auch der Treshold ist nicht notwendig. Dieser sorgt nur dafür, dass die Bilder geladen werden, bevor diese um den entsprechenden Pixelwert in den sichtbaren Bereich einlaufen.
 

golvreven

Gut bekanntes Mitglied
1. Oktober 2020
178
13
Hallo Martin,

ich habe die JS-Funktion bei uns im Bereich "Custom Javascript" des Salepix Plugins hinterlegt. Danach habe ich testweise die Bildpfade von src auf data-src geändert. Leider werden die entsprechenden Bilder nicht geladen.

Beim zweiten Versuch habe ich die JS-Funktion angepasst, weil die Klasse img-responsive hinterlegt ist.

$(function() {
$("img.img-responsive").lazy();
});

Ich habe auch src="[Bildpfad]" neben data-src="[Bildpfad]" stehen lassen. Leider funktioniert es nicht. Eventuell muss die Funktion an anderer Stelle hinterlegt werden.

Viele Grüße
g.
 
Zuletzt bearbeitet:

golvreven

Gut bekanntes Mitglied
1. Oktober 2020
178
13
Hallo noch einmal,

es funktioniert jetzt! Ich habe die JS-Funktion von css-umsetzung hinterlegt:

$(function() {
$('img.[css-klasse]').lazy(($(window).height() / 2), function() {
//
});
});

Die Bilder werden per lazyload nun geladen, wenn sie nur mit data-src hinterlegt sind. Ein Stellvertreterbild verwende ich nicht. Die Lösung ist natürlich noch nicht optimal im Hinblick auf Layout Shifting.

Allerdings kann ich nicht für alle Content-Bilder sprechen. Grafiken, die im Head-Bereich und im Footer eingebettet sind, kann ich mit der Funktion nicht auf der Startseite ansprechen. Auf der Startseite werden die Bilder dann weiterhin nicht über den Pfad data-src gefunden. Woran kann das liegen?

Viele Grüße
g.
 

golvreven

Gut bekanntes Mitglied
1. Oktober 2020
178
13
Und noch eine Wortmeldung zu dem Thema.

Leider gibt es mit der oben genannten Lösung ein Problem bei paginierten Seiten. Wenn ich beispielsweise ein Bild im SEO-Text unter Artikellistings per lazyload laden lasse, wird dieses nicht mehr geladen, wenn ich auf die ursprüngliche Seite zurückkehre. Ich meine es so:

1. Aufruf einer ersten Seite eines Artikellistings mit Bild unterm Listing > Bild wird per lazyload geladen
2. Aufruf einer zweiten Seite eines Artikellistings
3. Rückkehr von der zweiten auf die erste Seite eines Artikellistings mit Bild unterm Listing > Bild wird nicht mehr geladen

Woran kann das liegen?

Viele Grüße
g.
 

golvreven

Gut bekanntes Mitglied
1. Oktober 2020
178
13
Probier mal diesen Funktion, innerhalb von $(document).ready(){ /*hier*/ } aufzurufen.
Hallo wspread,

das macht leider keinen Sinn. Denn dann werden beispielsweise die Bilder in Artikellistings oder Slidern GAR nicht geladen. Ich muss dazusagen, dass unser Template lazyload von vornherein ausführt, jedoch nur für Artikellistings und Slider. Diese Automatik wird durch Deinen Vorschlag wahrscheinlich ausgehebelt.

Mein Problem ist: Beim Zurückblättern scheint die vormals aufgerufene Seite mit Artikellisting nicht wieder komplett geladen zu werden, sodass die von mir ergänzte lazyload-Funktion nicht ausgeführt wird.

Viele Grüße
g.
 

frijk

Gut bekanntes Mitglied
16. Juni 2009
211
6
Grundsätzlich: gibt es eine ähnliche Funktion wie für Bilder auch für <picture>-Elemente? Also können die srcset auch per Lazy-Funktion nachgeladen werden?

Aktuell noch Shop4, Vorbereitungen auf Update für Shop5 laufen schon, dauert aber noch ein bischen...

Danke vorab!
 
Ähnliche Themen
Titel Forum Antworten Datum
Neu Wie kann ich für einen Artikel einen alternativen Hersteller-Artikelnamen mitführen? User helfen Usern - Fragen zu JTL-Wawi 5
Neu WIe kann man A-Z Garantien verhindern ? Amazon-Lister - Fehler und Bugs 5
Neu Wie kann man so eine Ansicht ausliefern? JTL-Shop - Ideen, Lob und Kritik 1
Neu Wie kann man Push-Benachrichtigungen im Shop 5 anzeigen? Allgemeine Fragen zu JTL-Shop 0
Wie kann man FBA Bestellvorschläge generieren, wenn das FBA Lager Nachschub benötigt JTL-Wawi 1.6 7
Merkmale in Attribute umwandeln - wie geht das? JTL-Wawi 1.6 1
Neu Workflow - wie ist die Arbeitsweise ? User helfen Usern - Fragen zu JTL-Wawi 6
Neu Amazon Verkäuferkonto freigeschaltet - Produkte in JTL eingspielt, nun die Frage, 50.000 Artikel wie bekommt man diese mit EAN und teils ohne EAN Amazon-Anbindung - Ideen, Lob und Kritik 5
In Diskussion Workflow-Erweiterte Abfrage wie oft ein Artikel verkauft wurde JTL-Workflows - Ideen, Lob und Kritik 0
Neu JTL-AcademyDay 2022 - Wie geht das in der Datenbank? Du fragst, wir antworten! - Folgethread User helfen Usern - Fragen zu JTL-Wawi 19
Neu JTL-AcademyDay 2022 - Wie wird es richtig hübsch? Vorlagenanpassung in JTL-Wawi - Folgethread Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 14
Neu Exportformat Shop5 - wie JTL-Debug nicht helfen will User helfen Usern - Fragen zu JTL-Wawi 3
Neu Wenn das Mega-Menü öffnet, wurd unter dem Menü der Shop anders gefärbt - wie stylen? Templates für JTL-Shop 8
Neu Wie setze ich den Haken Bilderausgabe für Drucken/Mailen/Faxen für ALLE meine Artikel User helfen Usern - Fragen zu JTL-Wawi 4
Neu Shop lief ohne Wawi, Bestellungen manuell angelegt, wie weiter machen? Arbeitsabläufe in JTL-Wawi 0
Neu Klon von 4er Shop auf Staging Sudomain anlegen - wie gehe ich korrekt vor? Installation / Updates von JTL-Shop 2
Neu Newsletter verschicken? Wie? Hoster hat uns gekickt! Betrieb / Pflege von JTL-Shop 3
Neu Wie beendet ein normaler User den Worker .... User helfen Usern - Fragen zu JTL-Wawi 11
Neu Text (ca. 4000 Zeichen) auf Rechnung anzeigen lassen... wie geht's? User helfen Usern - Fragen zu JTL-Wawi 6
Neu JTL Header Plugin: Weitere Grafik/Badge neben dem Logo platzieren, wie? Templates für JTL-Shop 4
Neu Wie lautet der SQL Befehl zum löschen der Kommentare? User helfen Usern - Fragen zu JTL-Wawi 4
Neu DHL: Digitaler Einlieferungsbeleg, wie abschalten? JTL-ShippingLabels - Ideen, Lob und Kritik 1
Neu Kundennummer jährlich zurücksetzen? Wie macht ihr das User helfen Usern - Fragen zu JTL-Wawi 6
Angemeldete Retoure zurücknehmen - wie? JTL-Wawi 1.6 3
Neu Preiserhöhung mit Datum in Zukunft, aber Angebote mit längerer Laufzeit, wie vorgehen? User helfen Usern - Fragen zu JTL-Wawi 2
Neu Wie bekomme ich erweiterte Kundendaten im meine Rechnung? User helfen Usern - Fragen zu JTL-Wawi 7
Neu SW6 Aufträge werden zeitverzögert übertragen - Wie lösen? Shopware-Connector 0
Neu Testumgebung - Webshopabgleich ja, Fullfillment, eBay, Amazon etc. - Nein.Wie sicher vorgehen? User helfen Usern - Fragen zu JTL-Wawi 5
1.6. Tabelle tBestellungAttribute weg - Abfragen troztdem möglich - wie (lange) geht das? JTL-Wawi 1.6 3
Neu NOVA Template Theme mit komplett schwarzem Hintergrund - wie ansetzen? Templates für JTL-Shop 3
Neu Wie komm ich an die eigenen Felder (Firma) in den Druckvorlagen => Mailen => Email Text (Nicht List & Label) Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 8
Neu TIPP: Wie frage ich Variablen ab? Also das was in der ausgegeben wird. User helfen Usern - Fragen zu JTL-Wawi 3
Neu VCS Lite deaktiviert - wie geht's weiter? Amazon-Anbindung - Ideen, Lob und Kritik 4
Neu Wie stelle ich bei z.B. bei Amazon.com ein? User helfen Usern - Fragen zu JTL-Wawi 3
Neu Coupon für Artikel mit 7% und 19% USt wie lösen? Grundsätzliches JTL Shop Problem Allgemeine Fragen zu JTL-Shop 9
Neu MS SQL Express - Größe der Datenbank - wie viel ist noch frei? Wie ermitteln? User helfen Usern - Fragen zu JTL-Wawi 11
Neu Umzug auf JTL Shop - wie umgehen mit Länderdomains? Installation / Updates von JTL-Shop 2
Neu Bestehendes Shopware-Kundenkonto mit Wawi-Kundenkonto verknüpfen, wie? Shopware-Connector 2
Neu Wie binde ich Datenbankabfragen in den Formulareditor ein? User helfen Usern - Fragen zu JTL-Wawi 2
Neu Wie viele Mandanten "packt" die JTL-Wawi? Starten mit JTL: Projektabwicklung & Migration 5
Sendung an Postfiliale wie Adressieren? JTL-Wawi 1.6 27
Beantwortet Programm starten in C:\Program Files (x86)\JTL-Software (Ameise) - wie Pfad angeben? JTL-Workflows - Fehler und Bugs 8
Webinar: Meeting the new normal - Wie Corona das Verhalten der Onlineshopper änderte und was davon bleibt Messen, Stammtische und interessante Events 0
Neu Beleg an Eingangsrechnung anhängen. Wie geht das? Allgemeine Fragen zu JTL-Shop 0
Neu Kunde gesperrt kann trotzdem bestellen, immernoch nicht in Shop 5 geklärt? Arbeitsabläufe in JTL-Wawi 10
Neu {$favourableShippingString} wo kann ich diesen ändern? Technische Fragen zu Plugins und Templates 2
Neu Kann T&T wenn nicht leitcodierbar ist ... JTL-Track&Trace - Ideen, Lob und Kritik 0
Beantwortet Fehler: Artikelaktualisierung per Ameise - kann nicht vollständig aktualisiert werden weil er sich auf einer Pickliste befindet User helfen Usern - Fragen zu JTL-Wawi 1
Neu Ankerpunkt kann nicht richtig gesetzt werden JTL Shop 5 Allgemeine Fragen zu JTL-Shop 2
Vorlagen - wer kann helfen? Einrichtung JTL-Shop5 0

Ähnliche Themen