


JavaScript. So erstellen Sie ein blitzschnelles Multithread-Datenraster für Zeilen. Teil: Die Nuancen der Arbeit mit DOM
Demo | GitHub
Abbildung 1. Datenraster mit 1.000.000 Zeilen
Fast Data Grid-Funktionen:
- Unglaublich schnell
- Multithreaded
- Nur 523 Zeilen Code
- Keine Abhängigkeiten
- Vanille-JavaScript
Versuchen Sie, 1.000.000 Zeilen zu scrollen und zu durchsuchen – Fast Data Grid.
In diesem Artikel werde ich die Nuancen der Arbeit mit DOM auflisten. Über Multithreading im nächsten Artikel.
Je kleiner das DOM, desto besser. Das Ändern des Inhalts eines DIV ist schneller als das Löschen eines DIV und das Erstellen eines neuen.
Der Browser ist beim Rendern eines großen DOM-Baums langsam. Der Browser rendert überhaupt keine 1.000.000 Zeilen mit einer Höhe von 20 Pixeln – die maximale Höhe eines DIV in Chrome beträgt 15.000.000 Pixel. Je weniger HTML-Elemente, desto besser.
Fast Data Grid fügt dem DOM so viele Zeilen hinzu, wie auf den Bildschirm passen.
const rowsCount = Math.ceil(viewPortHeight / rowHeight);
Listing 1. Zählen, wie viele Zeilen auf den Bildschirm passen
Wenn neue Daten ausgegeben werden müssen, werden die Zeilen-DIVs wiederverwendet. Neue Daten werden in dieselben DIVs geschrieben. Das Ändern des Inhalts eines DIV geht schneller als das Löschen eines DIV und das Erstellen eines neuen.
Beim Scrollen wird die Position der DIV-Zeilen mithilfe von JavaScript berechnet.
Die maximale DIV-Höhe beträgt 15.000.000 Pixel
Damit das Scrollen funktioniert, erstellt Fast Data Grid einen großen DIV. Das Scroll-Ereignis ist an diesen DIV angehängt. Der Scroll-Event-Handler berechnet die Position der Zeilen-DIVs.
Abbildung 2. Großes DIV zum Scrollen
Wenn die Gesamthöhe der Zeilen mehr als 15.000.000 Pixel beträgt, sollten die Zeilen-DIVs schneller scrollen als die großen DIVs. Wenn der große DIV bis zum Ende scrollt -> Die Zeilen-DIVs sollten ebenfalls bis zum Ende scrollen.
Beim Scrollen von DIV-Zeilen muss ein Koeffizient angewendet werden.
const scrollYKoef = // if {allRowsHeight} > 15 million -> we have to applay koef on scroll // if {allRowsHeight} <= 15 million -> {scrollYKoef} = 1 (allRowsHeight - viewPortHeight) / (scrolHeight - viewPortHeight); listen(scrollOverlayDiv, 'scroll', /** @param {Event & {target:HTMLDivElement}} evt */ evt => { const scrollTop = evt.target.scrollTop * scrollYKoef; rowsDiv.style.transform = `translateY(${scrollTop}px)`; });
Listing 2. Verwendung des Koeffizienten beim Scrollen
Die CSS-Transformationsübersetzung ist schneller als CSS-Top
Beim Scrollen wird die Position per Transform Translate festgelegt. Die CSS-Transformationsübersetzung ist schneller als CSS-Top.
<!-- transform faster--> <div> <p><br> <em>Listing 3. CSS transform translate is faster than CSS top</em></p> <h2> Read DOM first, then modify DOM. It's bad to read DOM after modification </h2> <p>The browser displays frames on the monitor like this:<br> First, JavaScript is processed, then styles are calculated, then layout, then rendering.</p> <p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173464994174788.jpg" class="lazy" alt="JavaScript. How to Make a Blazingly Fast Multithreaded Data Grid for Rows. Part : The Nuances of Working with DOM" /><em>Figure 3. Standard order of operations when outputting a frame to the monitor</em></p> <p>If the standard order is not violated, the browser will render the frame as quickly as possible.</p> <p>At the beginning of the cycle, the DOM parameters are already calculated and correspond to the parameters of the previous frame. For example, box.offsetHeight is already calculated at the beginning of the cycle. But if you change the DOM and then read the DOM -> the browser will have to break the standard order. It will be necessary to calculate the layout again.<br> <pre class="brush:php;toolbar:false">box.classList.add('super-big'); // Gets the height of the box in pixels and logs it out: console.log(box.offsetHeight);
Listing 4. DOM vor dem Lesen von DOM ändern. Schlecht. Führt zu Layout-Überschneidungen.
Eine übermäßige Neuberechnung des Layouts wird als „Layout-Thrashing“ bezeichnet.
Eine visuelle Demonstration, wie das Ändern des DOM vor dem Lesen den Browser verlangsamt:
https://wilsonpage.github.io/fastdom/examples/animation.html
Toller Artikel zum Thema:
Vermeiden Sie große, komplexe Layouts und Layout-Überlastung | Artikel | web.dev.
Eigenwerbung
Ich erstelle den bequemsten Flussdiagramm-Editor DGRM.net.
Es ist auch der bequemste Service für Unternehmen: Excel-Geschäftsprozessdiagramme.
Vergeben Sie Sterne auf GitHub.
Das obige ist der detaillierte Inhalt vonJavaScript. So erstellen Sie ein blitzschnelles Multithread-Datenraster für Zeilen. Teil: Die Nuancen der Arbeit mit DOM. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

Zu den Hauptanwendungen von JavaScript in der Webentwicklung gehören die Interaktion der Clients, die Formüberprüfung und die asynchrone Kommunikation. 1) Dynamisches Inhaltsaktualisierung und Benutzerinteraktion durch DOM -Operationen; 2) Die Kundenüberprüfung erfolgt vor dem Einreichung von Daten, um die Benutzererfahrung zu verbessern. 3) Die Aktualisierung der Kommunikation mit dem Server wird durch AJAX -Technologie erreicht.

Die Anwendung von JavaScript in der realen Welt umfasst Front-End- und Back-End-Entwicklung. 1) Zeigen Sie Front-End-Anwendungen an, indem Sie eine TODO-Listanwendung erstellen, die DOM-Operationen und Ereignisverarbeitung umfasst. 2) Erstellen Sie RESTFUFFUPI über Node.js und express, um Back-End-Anwendungen zu demonstrieren.

Es ist für Entwickler wichtig, zu verstehen, wie die JavaScript -Engine intern funktioniert, da sie effizientere Code schreibt und Leistungs Engpässe und Optimierungsstrategien verstehen kann. 1) Der Workflow der Engine umfasst drei Phasen: Parsen, Kompilieren und Ausführung; 2) Während des Ausführungsprozesses führt die Engine dynamische Optimierung durch, wie z. B. Inline -Cache und versteckte Klassen. 3) Zu Best Practices gehören die Vermeidung globaler Variablen, die Optimierung von Schleifen, die Verwendung von const und lass und die Vermeidung übermäßiger Verwendung von Schließungen.

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Sowohl Python als auch JavaScripts Entscheidungen in Entwicklungsumgebungen sind wichtig. 1) Die Entwicklungsumgebung von Python umfasst Pycharm, Jupyternotebook und Anaconda, die für Datenwissenschaft und schnelles Prototyping geeignet sind. 2) Die Entwicklungsumgebung von JavaScript umfasst Node.JS, VSCODE und WebPack, die für die Entwicklung von Front-End- und Back-End-Entwicklung geeignet sind. Durch die Auswahl der richtigen Tools nach den Projektbedürfnissen kann die Entwicklung der Entwicklung und die Erfolgsquote der Projekte verbessert werden.

C und C spielen eine wichtige Rolle in der JavaScript -Engine, die hauptsächlich zur Implementierung von Dolmetschern und JIT -Compilern verwendet wird. 1) C wird verwendet, um JavaScript -Quellcode zu analysieren und einen abstrakten Syntaxbaum zu generieren. 2) C ist für die Generierung und Ausführung von Bytecode verantwortlich. 3) C implementiert den JIT-Compiler, optimiert und kompiliert Hot-Spot-Code zur Laufzeit und verbessert die Ausführungseffizienz von JavaScript erheblich.

JavaScript wird in Websites, mobilen Anwendungen, Desktop-Anwendungen und serverseitigen Programmierungen häufig verwendet. 1) In der Website -Entwicklung betreibt JavaScript DOM zusammen mit HTML und CSS, um dynamische Effekte zu erzielen und Frameworks wie JQuery und React zu unterstützen. 2) Durch reaktnatives und ionisches JavaScript wird ein plattformübergreifendes mobile Anwendungen entwickelt. 3) Mit dem Elektronenframework können JavaScript Desktop -Anwendungen erstellen. 4) Node.js ermöglicht es JavaScript, auf der Serverseite auszuführen und unterstützt hohe gleichzeitige Anforderungen.
