Slide 1

Slide 1 text

Session Blazor WebAssembly: Performanceoptimierungen fürs UI Patrick Jahr https://thinktecture.com/patrick-jahr @jahr_patrick Developer Consultant

Slide 2

Slide 2 text

Special Day Blazor Thema Sprecher Datum, Uhrzeit Blazor in .NET 7: Server, WebAssembly und Hybrid – ein Wegweiser Sebastian Gingter, Patrick Jahr DI, 11. Oktober 2022, 10.45 bis 11.45 Blazor WebAssembly: Performanceoptimierungen fürs UI Patrick Jahr DI, 11. Oktober 2022, 12.15 bis 13.15 Blazor Hybrid: Wie sich Blazor in WPF, Windows Forms und MAUI integriert Dr. Holger Schwichtenberg DI, 11. Oktober 2022, 15.30 bis 16.30 gRPC und Blazor WebAssembly: Ein Traumpaar? Christian Weyer DI, 11. Oktober 2022, 17.00 bis 18.00 Praxisnahes State Management in Blazor WebAssembly – Was sind denn das für Zustände? Sebastian Gingter DI, 11. Oktober 2022, 19.00 bis 20.00

Slide 3

Slide 3 text

Hello, it’s me. Patrick Jahr Developer Consultant @ Thinktecture AG E-Mail: [email protected] Twitter: @jahr_patrick Slides: https://thinktecture.com/patrick-jahr Blazor WebAssembly Performanceoptimierungen fürs UI Patrick Jahr

Slide 4

Slide 4 text

DEMO Blazor WebAssembly Performanceoptimierungen fürs UI P

Slide 5

Slide 5 text

Listen virtualisierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI P

Slide 6

Slide 6 text

Listen virtualisierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 7

Slide 7 text

- Müssen alle Elemente im DOM geladen sein? - Wie schnell komm ich an meine Daten für die Liste? - Optimierung: Virtualize Komponente - Nur der Sichtbereich wird geladen - Lazy Loading - Ladeanimation Blazor WebAssembly Performanceoptimierungen fürs UI Listenvirtualizierung

Slide 8

Slide 8 text

Blazor WebAssembly Performanceoptimierungen fürs UI Listenvirtualizierung Zeile außerhalb des Sichtbereichs Zeile im Sichtbereich Zeile außerhalb des Sichtbereichs Zeile im Sichtbereich ... Zeile außerhalb des Sichtbereichs Zeile außerhalb des Sichtbereichs

Slide 9

Slide 9 text

DEMO Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 10

Slide 10 text

Listen virtualizierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 11

Slide 11 text

Blazor WebAssembly Performanceoptimierungen fürs UI Wann wird eine Komponente gerendert? Initialisierung Änderung von Parametern Änderung von Parametern der übergeordneten Komponente DOM-Events StateHasChanged()

Slide 12

Slide 12 text

Blazor WebAssembly Performanceoptimierungen fürs UI Erstes Rendern? || ShouldRender() Render Component OnAfterRender/ OnAfterRenderAsync Render tree wird erstellt und an den DOM gesendet DOM Update Rendern wird beendet Nein Ja 1 2a 2b 3 4

Slide 13

Slide 13 text

Listen virtualizierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 14

Slide 14 text

- ShouldRender prüft ob eine Komponente gerendert werden soll - Methode der Basisklasse ComponentBase - Default Wert true - Optimierung - Komponenten Re-Rendring über eigene Logik steuern - Leicht für primitiven Typen wie string, int oder bool als Parameter - Aufwändiger für komplexe Typen Blazor WebAssembly Performanceoptimierungen fürs UI Clevere Komponenten

Slide 15

Slide 15 text

DEMO Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 16

Slide 16 text

Listen virtualizierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 17

Slide 17 text

Blazor WebAssembly Performanceoptimierungen fürs UI Erstes Rendern? || ShouldRender() DOM Event oninput, onclick, onblur,... Event Handler ausführen Render Component OnAfterRender/ OnAfterRenderAsync Render tree wird erstellt und an den DOM gesendet DOM Update Rendern wird beendet Nein Ja 1 2 3 4a 4b 5 6

Slide 18

Slide 18 text

- Durch jedes Event wird die Methode HandleEventAsync des Interface IHandleEvent in der Basisklasse ComponentBase aufgerufen - Optimierung - Interface IHandleEvent in der Komponenten Klasse implementieren - Einsatz der Hilfsklasse EventUtils, die von Microsoft angeboten wird - Hinweis: Die Hilfsklasse muss dem Projekt selbst hinzugefügt werden EventUtils: https://docs.microsoft.com/de-de/aspnet/core/blazor/webassembly-performance-best-practices?view=aspnetcore-6.0#avoid-rerendering-after-handling-events- without-state-changes Blazor WebAssembly Performanceoptimierungen fürs UI Events-Reaction

Slide 19

Slide 19 text

DEMO Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 20

Slide 20 text

Was tun wenn das Re-Rendering nach einem Event benötigt wird? - Debounce Events - Throttle Events - Slice Events Blazor WebAssembly Performanceoptimierungen fürs UI Events-Reaction

Slide 21

Slide 21 text

DEMO Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 22

Slide 22 text

Listen virtualizierung Render Prozess Clevere Komponenten Events- Reaction Resümee Blazor WebAssembly Performanceoptimierungen fürs UI

Slide 23

Slide 23 text

- Listenoptimierung durch Virtualize-Komponente - Muss meine Komponente wirklich immer gerendert werden? - Soll ein Event immer ein Re-Rendering triggern? Blazor WebAssembly Performanceoptimierungen fürs UI Resümee

Slide 24

Slide 24 text

https://www.thinktecture.com/ueber-uns/karriere/ Dankeschön! Patrick Jahr https://thinktecture.com/patrick-jahr Demos aus der Session: https://github.com/thinktecture-labs/basta-fall-2022- blazor-wasm-performance