PubTech konnte mit seiner Plattform zur Einwilligungsverwaltung den INP auf den Websites seiner Kunden um bis zu 64 % senken und gleichzeitig die Anzeigensichtbarkeit um bis zu 1,5 % verbessern

PubConsent CMP reduziert den INP-Wert seiner Kunden um bis zu 64% mit einer Ertragsstrategie, bei der mithilfe der Scheduler APIs des Browsers Reaktionsprobleme behoben werden, die mit den Chrome-Entwicklertools identifiziert wurden.

Marco Prontera
Marco Prontera
Gilberto Cocchi
Gilberto Cocchi

Plattformen zur Einwilligungsverwaltung (Consent Management Platforms, CMPs) sind Tools, die Websites dabei unterstützen, Datenschutzbestimmungen einzuhalten, indem sie die Nutzereinwilligung zur Verwendung von Cookies und Tracking-Technologien einholen. Zusätzlich zum Hauptziel der Einhaltung gesetzlicher Vorschriften müssen CMPs als Drittanbieterskripts auch minimale Auswirkungen auf die Leistung und die Nutzerfreundlichkeit haben.

PubConsent CMP ist das neueste Produkt von PubTech. PubConsent CMP wurde mit dem Schwerpunkt auf Leistung entwickelt und ist so schlank, dass eine optimale Nutzererfahrung und die Auswirkungen auf die Gesamtleistung der Website minimiert werden.

Mit der Einführung des Messwerts Interaction to Next Paint (INP) konnte PubTech Probleme mit der Reaktionsschnelligkeit unserer CMP erkennen. In dieser Fallstudie zeigt PubTech, wie es seine Probleme mit der Reaktionsschnelligkeit seiner PubConsent-CMP-Plattform gelöst hat und wie das INP verbessert wurde, bevor es im März 2024 zu einem der Core Web Vitals wurde. Das zeigt, dass das Unternehmen unerschütterlich bemüht ist, die bestmögliche Leistung in einem CMP-Produkt zu bieten.

Warum ist PubTech die Leistung wichtig?

Wie die meisten CMPs bietet PubConsent-CMP die Funktionen zur Einwilligungsverwaltung als Drittanbieterskript auf den Seiten der Website ein. Für eine erfolgreiche CMP-Integration ist es wichtig, die Auswirkungen unseres CMP-Angebots auf die Leistung zu minimieren, einschließlich der Reaktionszeit.

Indem Websiteinhaber die Leistung priorisieren und das CMP-Script von PubConsent schlank halten, können Websiteinhaber*innen ein ausgewogenes Verhältnis zwischen der Einbindung nützlicher Funktionen zur Einwilligungsverwaltung bei gleichzeitiger Wahrung der Nutzerfreundlichkeit finden.

Aufgrund der Bedeutung der Funktionalität und der möglichen Auswirkungen einer CMP auf die Leistung hat PubTech die folgenden Ziele festgelegt:

  1. Minimieren Sie die Auswirkungen des PubConsent-CMP-Produkts auf INP.
  2. Reduzieren Sie lange auf das CMP-Produkt zurückzuführende Aufgaben.
  3. Verringern Sie die Total Blocking Time (TBT), was sich negativ auf den INP einer Seite auswirken kann.

So wurde INP gemessen

PubTech führte eine erste Analyse mit den Chrome-Entwicklertools durch und diagnostizierte langsame Interaktionen manuell. Dieser Workflow ermöglichte es PubTech, spezifische Probleme zu ermitteln, die sich auf die Reaktionszeit von Seiten auswirkten. Eine Klickinteraktion innerhalb der CMP, bei der alle Cookies akzeptiert und anschließend der Dialog zur Cookie-Einwilligung geschlossen wird, verursachte eine lange Aufgabe, die ein Rendering-Update der Benutzeroberfläche verzögerte. Wie Sie in der folgenden Abbildung sehen können, wurde die Benutzeroberfläche erst aktualisiert, um anzuzeigen, dass das Dialogfeld erst geschlossen war, nachdem die lange Aufgabe abgeschlossen war.

Wie die Schaltfläche zum Akzeptieren aller Cookies folgt auch die Schaltfläche zum Ablehnen aller Cookies oder Anpassen der Cookie-Einstellungen dem gleichen Workflow in der PubConsent-CMP-Architektur. Aus diesem Grund wirkten sich die in dieser Fallstudie beschriebenen Verbesserungen auf eine Reihe von Nutzerinteraktionen in der CMP aus.

Ein Ablauf, der zeigt, wie eine lange Aufgabe die Benutzeroberfläche daran hindert, die Benutzeroberfläche zu aktualisieren, nachdem der Nutzer in der PubConsent-CMP auf die Schaltfläche „Accept All“ (Alle akzeptieren) geklickt hat. Die fünf Schritte umfassen eine einzelne, lange Aufgabe, wodurch die Benutzeroberfläche langsam wirkt.
Visuelle Darstellung dessen, was passiert, wenn Nutzer auf die Schaltfläche „Alle akzeptieren“ klicken.

Diese Verzögerung führte dazu, dass das Panel während der Aufgabe visuell gesperrt war. Da das Rendering-Update für einen deutlich langen Zeitraum blockiert wurde, wirkte sich dies negativ auf die INP der Seite aus.

Zur Verbesserung des INP wurden verschiedene Ertragsstrategien in die PubConsent-CMP eingeführt.

Ergeben von Aufgaben mit hoher Priorität

Die im folgenden Code-Snippet gezeigte Methode yieldToMainUiBlocking wurde entwickelt, um JavaScript-Aufgaben mit hoher Priorität zu optimieren. Dazu wird mit scheduler.yield (sofern verfügbar) zurückgegeben, aber bei Verfügbarkeit von postTask auf postTask mit der Priorität user-blocking (hohe Priorität) und schließlich auf nichts zurückgesetzt.

setTimeout wurde hier vermieden, weil die yieldToMainUiBlocking-Methode für interne CMP-Einstellungsvorgänge und Aufgaben mit hoher Priorität vorgesehen ist, die diese Priorität beim Ertrag beibehalten sollen. Das bedeutet, dass nur Browser mit diesen Planungs-APIs – die zum Zeitpunkt der Erstellung dieses Dokuments nur in Chromium-basierten Browsern verfügbar waren – von den in dieser Fallstudie beschriebenen Verbesserungen profitieren. Dennoch wurde dieser Ansatz als akzeptable progressive Verbesserung für diese Aufgaben mit hoher Priorität angesehen.

function yieldToMainUiBlocking () {
  return new Promise((resolve) => {
    if ('scheduler' in window) {
      if ('yield' in window.scheduler) {
        return window.scheduler.yield().then(() => resolve(true));
      }

      if ('postTask' in window.scheduler) {
        return window.scheduler.postTask(() => resolve(true), { priority: 'user-blocking' });
      }
    }

    resolve(false);
  });
};

Erzielt bei Aufgaben mit mittlerer und im Hintergrund erledigter Aufgaben

Die im folgenden Code-Snippet gezeigte Methode yieldToMainBackground wird verwendet, um lange Aufgaben mit der Priorität user-visible (mittel) oder background aufzuteilen. Die Logik implementiert scheduler.yield(), wenn es verfügbar ist, unterscheidet sich jedoch dadurch, dass postTask mit mittlerer Priorität verwendet wird und schließlich in Nicht-Chromium-Browsern auf setTimeout zurückfällt.

function yieldToMainBackground () {
  return new Promise((resolve) => {
    if ('scheduler' in window) {
      if ('yield' in window.scheduler) {
        return window.scheduler.yield().then(() => resolve(true));
      }

      if ('postTask' in window.scheduler) {
        return window.scheduler.postTask(() => resolve(true), { priority: 'user-visible' });
      }
    }

    setTimeout(() => { resolve(true) }, 0);
  });
};
Ein Ablauf, der zeigt, wie die lange Aufgabe, die das Aktualisieren der Benutzeroberfläche blockiert hat, nachdem der Nutzer auf die Schaltfläche „Alle akzeptieren“ in der PubConsent-CMP geklickt hat, optimiert wurde. Wenn möglich, erzielen Sie mit den fünf Schritten nun Ergebnisse, sodass die Benutzeroberfläche das Rendering früher aktualisieren kann.
Visuelle Darstellung, wie der Browser mit yieldToMainBackground den nächsten Paint (in diesem Fall die CMP-UI schließen) schneller rendern kann.

Wie PubTech seine TBT durch Rendering-Layoutoptimierung weiter reduziert hat

Nach Anwendung der Ertragsstrategie stellte sich heraus, dass sich INP für die CMP deutlich verbessert hatte. Nachdem die Verarbeitungsdauer des Event-Handlers erheblich verkürzt wurde, gab es die Möglichkeit, das Rendering für das nächste Painting für die Aktion UI schließen weiter zu verbessern. Diese Aktion wurde ursprünglich zum Entfernen von Elementen aus dem DOM entwickelt. Dies stellte vor allem auf Websites mit einer großen Anzahl von DOM-Knoten Herausforderungen mit sich, was zu einem unerwarteten Anstieg der Rendering-Arbeit führte.

Screenshot des Bereichs „Leistung“ in den Chrome-Entwicklertools mit einem Trace-Abschnitt mit einem Aufrufstack von Aktivitäten zum Schließen eines UI-Dialogfelds in der PubConsent-CMP. Die Aufgabe zum Schließen des UI-Dialogfelds selbst löst das Entfernen von DOM-Knoten aus, was die Darstellungsverzögerung der Interaktion erhöht.

Um dem erhöhten Rendering-Arbeitsaufwand zum Entfernen von Elementen aus dem DOM entgegenzuwirken, wurde eine Lösung eingeführt, die das Team als „Lazy De-Rendering“ nannte. Bei diesem Ansatz wird zuerst die CSS-Regel display: none auf das Einwilligungsdialogfeld der CMP angewendet, nachdem der Nutzer seine Einwilligung zum Ausblenden erteilt hat. Dann werden die mit dem CMP-Dialogfeld verknüpften DOM-Knoten mithilfe von requestIdleCallback auf einen späteren Zeitpunkt verschoben, zu dem der Browser inaktiv ist. Dieser Ansatz erwies sich als viel schneller als das Entfernen von DOM-Knoten zu dem Zeitpunkt, an dem der Nutzer den Dialog zur Einholung von Einwilligungen geschlossen hat.

Screenshot des Bereichs „Leistung“ in den Chrome-Entwicklertools mit dem gleichen Trace wie zuvor, aber optimiert. Wenn das Dialogfeld der PubConsent-CMP geschlossen wird, besteht die erste Aktion darin, es über die „CSS display: none“-Regel auszublenden. Wenn der Browser später inaktiv ist, wird der DOM-Knoten entfernt.
Screenshot der Entwicklertools, der die INP-Verbesserung durch Verschieben der Aufgabe zum Entfernen des DOMs zeigt.

Wie PubTech den INP durch Verbesserung der IAB TCF-Bibliothek weiter reduziert hat

Nachdem die meisten Probleme im Zusammenhang mit der Reaktionszeit der CMP behoben wurden, wurden in einer der Hauptabhängigkeiten weitere Verbesserungsmöglichkeiten identifiziert: die Bibliothek des IAB Transparency and Consent Framework (TCF).

Die rechenintensivsten Komponenten dieser Bibliothek waren „Strings erstellen“ und „Einwilligung senden“. Diese Komponenten sind wesentliche Bestandteile der IAB TCF-Bibliothek. Die folgenden Optimierungen für diese Komponenten wurden in einer separaten Verzweigung speziell für die Anforderungen von PubTech angewendet:

  1. Wiederverwendung berechneter Ergebnisse für den Decodierungsprozess, der für jeden Drittanbieter-Callback ausgeführt wird, der die Einwilligung des Nutzers lesen muss
  2. Unnötige Schleifen im Codierungsprozess für Publisher-Einschränkungen, der ausgeführt wird, wenn der Nutzer seine Einwilligung erteilt, wurden vermieden und es werden unnötige Schleifen vermieden.

Mit der ersten dieser Optimierungen reduziert die CMP die Zeit, die die CMP für jeden Drittanbieter-Callback aufwendet, der in die IAB TCF-Bibliothek eingebunden wird. Durch die zweite Optimierung wurde die Verarbeitungsdauer für die Komponente zum Erstellen von Strings reduziert. Durch diese Optimierung konnten bis zu 60% der Schleifen reduziert werden, die jedes Mal ausgeführt werden, wenn ein Nutzer seine Einwilligung erteilt hat.

Ergebnisse

Mit den bisherigen Strategien und neuen Rendering-Layouts konnte der INP-Wert der CMP um bis zu 65%gesteigert werden. Das Ergebnis: Die Nutzerfreundlichkeit der PubConsent-CMP konnte erheblich verbessert werden.Bei einigen Anzeigen konnte die Sichtbarkeit sogar um 1,5% verbessert werden, indem bei der Anzeigenanforderung eine Optimierung vorgenommen wurde.

Zusätzlich zu diesen Verbesserungen konnte in der TCF-Bibliothek des IAB festgestellt werden, dass INP bei betroffenen Kunden um bis zu 77% verbessert wurde, da die durch das TCF ausgelösten langen Aufgaben um bis zu 85 % reduziert wurden. Dadurch konnte der Aufwand für Drittanbieter-Callbacks erheblich reduziert werden, die während des gesamten Lebenszyklus einer Seite ausgeführt werden.

Die Anzahl der Quellen, die INP bestehen, wenn sie PubConsent-CMP nutzten, verbesserte sich um mehr als 400%, von 13% auf 55% auf Mobilgeräten. Bei einigen Kunden konnte die Page INP durch die PubTech SDK-Optimierungen um mehr als die Hälfte reduziert werden – von 470 Millisekunden auf 230 Millisekunden.

Screenshot der ursprünglichen INP-Erfolgsquoten für Websites, die die PubTech-CMP verwenden. Auf Desktop-Geräten verbessern sich die Erfolgsquoten von etwa 84% auf 99, 12%. Auf Mobilgeräten verbessern sich die Erfolgsquoten von etwa 22% auf 55, 46%.
Die Ursprungs-INP-Passrate für Websites, die PubTech-CMP verwenden, wie im HTTP-Archiv und im Bericht zur Nutzererfahrung in Chrome angegeben.
Screenshot eines Dashboards mit INP aus RUM-Daten beim 75. Perzentil. Von Juli/Augst 2023 betrug INP knapp unter 500 Millisekunden, Mitte Februar 2024 liegt sie jedoch knapp unter 200 Millisekunden und liegt damit im Grenzwert „Gut“.
Der Trend zur Verbesserung der mobilen INP-Daten des PubConsent-Kunden entspricht den in dieser Fallstudie beschriebenen SDK-Änderungen.

Fazit

Die Kunden von PubTech haben schon schnell die positiven Ergebnisse der INP-Leistung und der Geschäftsmetriken erkannt, die sich aus unseren Optimierungsmaßnahmen ergeben haben. Weitere Leistungsverbesserungen für die PubConsent-CMP werden in Betracht gezogen und es werden wertvolle RUM-Daten (Real User Monitoring) ihrer Kunden genutzt. Diese Daten verfolgen sowohl Regressionen als auch Fortschritte genau und fördern die kontinuierlichen Verbesserungsmaßnahmen von PubTech.

Als Drittanbieter erkannte PubTech auch, dass es die Möglichkeit bietet, die Webleistung in großem Maßstab zu verbessern und schneller reagieren zu können, ohne negative Auswirkungen auf die geschäftlichen KPIs zu vermeiden. Für diese Verbesserungen ist es nie zu spät!

Unser besonderer Dank geht an Luca Coppola, CTO bei PubTech zur Unterstützung dieser Innovationsarbeit, sowie an Jeremy Wagner, Michal Mocny und Rick Viscomi von Google.