So vermeiden Sie unnötiges CSS-Reflow und Neuzeichnen
In der Frontend-Entwicklung ist CSS ein unverzichtbarer Bestandteil. Allerdings kann die unsachgemäße Verwendung von CSS zu einer verminderten Seitenleistung führen, wobei das häufigste Problem unnötige CSS-Reflows und Neuzeichnungen sind. In diesem Artikel werden einige Tipps und spezifische Codebeispiele vorgestellt, die Ihnen helfen, diese Probleme zu vermeiden und die Leistung Ihrer Seiten zu verbessern.
Reflow und Neuzeichnen werden basierend auf Änderungen in den Stilattributen von DOM-Elementen ausgelöst, sodass häufige Stilaktualisierungen die Anzahl der Reflows und Neuzeichnungen erhöhen. Um dieses Problem zu vermeiden, können Sie die Anzahl der Reflows und Neuzeichnungen reduzieren, indem Sie Stilaktualisierungen in einem einzigen Vorgang konzentrieren. Wenn Sie beispielsweise mehrere Stilattribute eines Elements ändern müssen, können Sie eine Klasse hinzufügen, anstatt die Attribute einzeln zu ändern. Der Beispielcode lautet wie folgt:
// 不推荐的写法 element.style.width = '100px'; element.style.height = '200px'; element.style.background = 'red'; // 推荐的写法 element.classList.add('my-class');
Das Ändern von Stileigenschaften in einer Schleife ist ein häufiges Problem, da jede Änderung einen Umfluss und ein Neuzeichnen verursacht. Um dieses Problem zu vermeiden, können Sie die Berechnung und Änderung von Stileigenschaften außerhalb der Schleife verschieben. Der Beispielcode lautet wie folgt:
// 不推荐的写法 for (let i = 0; i < elements.length; i++) { elements[i].style.width = i * 10 + 'px'; } // 推荐的写法 let styles = ''; for (let i = 0; i < elements.length; i++) { styles += `#${elements[i].id} { width: ${i * 10}px; }`; } element.styleSheet ? element.styleSheet.cssText = styles // IE : element.innerHTML = styles; // Others
Die Verwendung von JavaScript zur Implementierung von Animationen kann zu häufigen Reflows und Neuzeichnungen führen. Im Gegensatz dazu ist die Verwendung von CSS-Animationen effizienter, da sie die Hardwarebeschleunigung nutzen können. Der Beispielcode lautet wie folgt:
/* CSS */ @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } } /* JavaScript */ element.classList.add('spin');
CSS3 führt einige Eigenschaften ein, die die Leistung von Reflow und Neuzeichnen optimieren können. Verwenden Sie beispielsweise transform
anstelle von left
und top
, um die Position eines Elements zu ändern, oder verwenden Sie translate3d
, um Hardwarebeschleunigung aktivieren. Der Beispielcode lautet wie folgt: transform
代替left
和top
来改变元素的位置,或者使用translate3d
开启硬件加速。示例代码如下:
/* 不推荐的写法 */ element.style.left = '100px'; element.style.top = '200px'; /* 推荐的写法 */ element.style.transform = 'translate(100px, 200px)';
will-change
属性will-change
属性可以告诉浏览器元素将要发生的变化,从而提前进行优化。使用will-change
属性可以让浏览器知道哪些属性可能会触发回流或重绘,从而提前进行优化。示例代码如下:
.element { will-change: transform; }
总结
通过避免频繁更新样式、在循环中修改样式、使用CSS动画代替JavaScript动画、使用CSS3属性优化性能和使用will-change
rrreee
will-change
🎜🎜🎜Das Attribut will-change
kann es dem Browser mitteilen die Änderungen, die am Element auftreten, und optimieren so im Voraus. Durch die Verwendung des Attributs will-change
kann der Browser wissen, welche Eigenschaften einen Reflow oder ein Neuzeichnen auslösen können, sodass eine Optimierung im Voraus durchgeführt werden kann. Der Beispielcode lautet wie folgt: 🎜rrreee🎜Zusammenfassung🎜🎜Durch die Vermeidung häufiger Aktualisierungen von Stilen, die Änderung von Stilen in Schleifen, die Verwendung von CSS-Animationen anstelle von JavaScript-Animationen, die Verwendung von CSS3-Eigenschaften zur Optimierung der Leistung und die Verwendung von will-change Mit dem Attribut code> können wir unnötigen CSS-Reflow und Neuzeichnen effektiv vermeiden und die Seitenleistung verbessern. Natürlich sollte die spezifische Optimierungsmethode auch an die Bedürfnisse und spezifischen Umstände des Projekts angepasst und optimiert werden. 🎜
Das obige ist der detaillierte Inhalt vonTipps zur Optimierung von CSS, um Seitenumbrüche und Neulackierungen zu reduzieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!