


Optimizing front-end performance: tips and methods to reduce redraws and reflows
Improve front-end performance: Tips and methods to avoid redrawing and reflow
In front-end development, optimizing performance is an important topic. Among them, avoiding unnecessary redraw (Repaint) and reflow (Reflow) operations is the key to improving page performance. This article will introduce some techniques and methods that can help developers avoid redrawing and reflowing, and give specific code examples.
1. What is redrawing and reflow
- Redrawing: When the style of a DOM element changes, but does not affect its geometric properties (such as position and size), the browser A redraw operation will be performed. Redrawing refers to updating the visual effect of an element without affecting the layout.
- Reflow: When the geometric properties of a DOM element change, the browser needs to recalculate the geometric properties of the element and re-layout the page. This process is called reflow.
Redrawing and reflow will cause certain performance consumption. If they occur frequently, it will seriously affect the performance of the page.
2. Tips and methods to avoid redrawing and reflow
- Use class instead of style: When setting the element style, try to use class to modify the element's style instead of directly operating it The style attribute of the element. Because modifying the style attribute will cause a reflow operation, using class to modify the style will only trigger a redraw.
Sample code:
// 不推荐的写法 element.style.width = '200px'; element.style.height = '100px'; element.style.backgroundColor = 'red'; // 推荐的写法 element.classList.add('custom-style');
- Use document fragment (DocumentFragment): When adding a large number of DOM elements to the page, you can first add these elements to the document fragment, Then insert the document at once, which can reduce the number of reflows.
Sample code:
const fragment = document.createDocumentFragment(); for (let i = 0; i < 1000; i++) { const div = document.createElement('div'); div.innerHTML = 'Element ' + i; fragment.appendChild(div); } document.getElementById('container').appendChild(fragment);
- Use transform instead of top/left: When you need to change the position of an element, try to use the transform attribute instead of directly modifying top and left left attribute. Because using transform will not trigger a reflow operation, directly modifying the top and left properties will cause the browser to recalculate the layout of the element.
Sample code:
// 不推荐的写法 element.style.top = '100px'; element.style.left = '200px'; // 推荐的写法 element.style.transform = 'translate(200px, 100px)';
- Use virtual DOM (Virtual DOM): Virtual DOM is an in-memory data structure, by comparing the difference between virtual DOM and real DOM , minimizing page redraw and reflow operations. Using some popular front-end frameworks (such as React, Vue) will automatically help you operate virtual DOM.
Sample code:
// 使用 React 创建虚拟 DOM const element = <div>Hello, World!</div>; // 将虚拟 DOM 导入真实 DOM ReactDOM.render(element, document.getElementById('root'));
Summary:
Redrawing and reflow are issues that require special attention in front-end performance optimization. By using class instead of style, using document fragments, using transform instead of top/left, and using virtual DOM and other techniques and methods, we can significantly reduce page redraw and reflow operations and improve page performance. In actual development, it is recommended that developers always pay attention to the performance of the page and follow the above tips and methods for optimization.
The above is the detailed content of Optimizing front-end performance: tips and methods to reduce redraws and reflows. For more information, please follow other related articles on the PHP Chinese website!

In a perfect world, our projects would have unlimited resources and time. Our teams would begin coding with well thought out and highly refined UX designs.

Oh, the Many Ways to Make Triangular Breadcrumb Ribbons

SVG has its own set of elements, attributes and properties to the extent that inline SVG code can get long and complex. By leveraging CSS and some of the forthcoming features of the SVG 2 specification, we can reduce that code for cleaner markup.

You might not know this, but JavaScript has stealthily accumulated quite a number of observers in recent times, and Intersection Observer is a part of that

We may not need to throw out all CSS animations. Remember, it’s prefers-reduced-motion, not prefers-no-motion.

PWA (Progressive Web Apps) have been with us for some time now. Yet, each time I try explaining it to clients, the same question pops up: "Will my users be

It's extremely surprising to me that HTML has never had any way to include other HTML files within it. Nor does there seem to be anything on the horizon that

There are a lot of different ways to use SVG. Depending on which way, the tactic for recoloring that SVG in different states or conditions — :hover,


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Dreamweaver Mac version
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

WebStorm Mac version
Useful JavaScript development tools