Heim >Web-Frontend >Front-End-Fragen und Antworten >Was ist Reflow in Javascript?

Was ist Reflow in Javascript?

青灯夜游
青灯夜游Original
2021-11-19 17:54:443923Durchsuche

In JavaScript wird Reflow auch als Reflow bezeichnet. Dies bezieht sich auf den Prozess, bei dem der Browser einen Teil oder das gesamte DOM neu rendert, wenn sich ein Teil oder der gesamte Rendering-Baum aufgrund von Änderungen in der Größe, im Layout, beim Ausblenden usw. ändert . der Elemente; einfach ausgedrückt, was bedeutet, dass die gesamte Seite neu formatiert wird.

Was ist Reflow in Javascript?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, JavaScript-Version 1.8.5, Dell G3-Computer.

Lassen Sie uns kurz den Rendering-Prozess des Browsers verstehen (Bilder kommen aus dem Internet)

Was ist Reflow in Javascript?

Der Prozess, bei dem der Browser den Rendering-Baum generiert (Bilder kommen aus dem Internet)

Was ist Reflow in Javascript?

Reflow

Wenn sich ein Teil oder der gesamte Rendering-Baum aufgrund der Größe, des Layouts, des Ausblendens usw. der Elemente ändert, rendert der Browser einen Teil oder das gesamte DOM neu.

Reflow wird auch als Neuanordnung bezeichnet. Tatsächlich ist die Neuanordnung im wahrsten Sinne des Wortes einfacher zu verstehen (dh die Neuanordnung der gesamten Seite).

Neu zeichnen

Wenn die Änderung des Seitenelementstils keinen Einfluss auf die Position des Elements im Dokumentfluss hat (z. B. Hintergrundfarbe, Rahmenfarbe, Sichtbarkeit), weist der Browser dem Element nur den neuen Stil zu und zeichnet es neu.

Wann wird Reflow oder Repaint ausgelöst?

Es gibt eine große Anzahl von Benutzerverhalten und potenziellen DHTML-Änderungen, die einen Reflow auslösen können. Ändern Sie beispielsweise die Größe des Browserfensters, verwenden Sie einige JavaScript-Methoden, einschließlich der Berechnung von Stilen, dem Hinzufügen oder Entfernen von Elementen zum DOM oder dem Ändern der Elementklasse usw.

添加或者删除可见的DOM元素;
元素位置改变;
元素尺寸改变——边距、填充、边框、宽度和高度;
内容变化,比如用户在input框中输入文字,文本或者图片大小改变而引起的计算值宽度和高度改变;
页面渲染初始化;
浏览器窗口尺寸改变,resize事件发生时;
计算offsetWidth和offsetHeight属性;
设置style属性的值;

Reflow führt definitiv zu einem Neuzeichnen, aber ein Neuzeichnen führt nicht unbedingt zu einem Reflow.

Wie kann man Reflow und Neuzeichnen reduzieren?

1. Vermeiden Sie Reflow und Neuzeichnen in CSS

1. Ändern Sie die Klasse am Ende des DOM-Baums so weit wie möglich.
2 Vermeiden Sie das Festlegen mehrerer Ebenen von Inline-Stilen.
3 Absolut oder fest
4. Vermeiden Sie die Verwendung von Tabellenlayout
5. Verwenden Sie CSS3-Hardwarebeschleunigung, um zu verhindern, dass Animationseffekte wie Transformation, Deckkraft und Filter ein Reflow- und Neuzeichnen verursachen

1 Verwenden von JS Nachdem Sie einen Stil geändert und dann den nächsten Stil geändert haben, ist es am besten, den CSS-Stil sofort zu ändern oder die Stilliste als Namen der Klasse zu definieren

2. Vermeiden Sie häufige DOM-Operationen und verwenden Sie Dokumentfragmente, um einen Unterbaum zu erstellen , und kopieren Sie es dann in das Dokument

3. Blenden Sie das Element zuerst aus und zeigen Sie es dann nach der Änderung an, da DOM-Operationen auf display:none keinen Reflow und kein Neuzeichnen verursachen
4. Vermeiden Sie Schleifen, um Attribute wie offsetLeft und zu lesen Speichern Sie sie vor der Schleife
5. Verwenden Sie bei komplexen Animationseffekten die absolute Positionierung, um sie vom Dokumentfluss zu trennen, da es sonst zu einer großen Anzahl von Reflows des übergeordneten Elements und nachfolgender Elemente kommt

Zusammenfassung:

Reflow ist ein Benutzer- Daher ist es für die Front-End-Entwicklung sehr hilfreich, zu wissen, wie sich die Reflow-Zeit verbessern lässt, und die Auswirkungen verschiedener Dokumenteigenschaften (DOM-Knotentiefe, CSS-Rendering-Effizienz, verschiedene Stiländerungen) auf die Reflow-Zeit zu kennen. Manchmal kann sogar das Umfließen eines einzelnen Elements erfordern, dass sein übergeordnetes Element und alle folgenden Elemente ebenfalls umgebrochen werden. Wenn Sie beispielsweise den Hintergrund eines Elements ändern müssen, betrifft dies nicht die Attribute des Elements, sondern es erfolgt nur eine Neuzeichnung.

【Empfohlenes Lernen:

Javascript-Tutorial für Fortgeschrittene

Das obige ist der detaillierte Inhalt vonWas ist Reflow in Javascript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn