First off, what are Repaint and Reflow in the Browser
- Repaint
- It occurs when changes are made to the appearance of the elements that changes visibility, but doesn't effect the layout
- Reflow
- It re-calculates the position and geometries of the elements in the document.
  Reflow happens when changes are made to the elements, that effects partial or the whole page.
Most importantly Reflow of the element will cause the subsequent reflow of all the child and ancestor elements in the DOM
to understand this concept we need to get into how browser renders the website forehead
This is a brief explanation of how browser renders the website.

- when the users enter the URL, it will fetch the HTML source code from the server
- Browser parse the HTML source code and convert into token 
 < TagName, Attribute, AttributeValue, >
- These tokens will converted into nodes and will construct DOM Tree
- The CSSOM Treewill be generated from CSS rules
- The DOMandCSSOM Treewill combine into theRender Tree
- The Render Tree are constructed as below:
- Start from the root of the DOM Tree and compute which elements are visibleandtheir computed styles
- Render Treewill ignore the not visible elements like- (meta, script, link) and display:none
- It will match the visible node to the appropriate CSSOM rules and apply them
 
- Start from the root of the DOM Tree and compute 
- Reflow: Calculate the position and size of each visible node
- Repaint: Now, The browser will- paintthe- Render Treeon the screen
So, Why reflow and repaint is so important ??
Reflows are very expensive in terms of performance, and is one of the main causes of slow DOM scripts, especially on devices with low processing power, such as phones. In many cases, they are equivalent to laying out the entire page again.
Basically, most reflows essentially cause page to be re-rendered
which is very expensive work for browser to do if it happens so many times and so often as well as repaint ( not exactly the same tho )
These are the lists of what causes browser to reflow and repaint
- When adding,removing,updatingthe DOM nodes.
- display : none: causes both reflow and repaint
- visibility : hidden: causes only repaint ( no layout or position change)
- Adjusting,- AnimatingDom node will trigger reflow and repaint
- Resizingthe window trigger reflow
- Changing font-stylealters geometry of the element which it affects the position or size of the other element on the page,- The browser to perform reflow. Once those layout operations have completed any damaged pixels will need to be a repaint
 
- Addingor- RemovingStylesheet will cause the reflow and repaint
- Script manipulatingthe DOM is the expensive operation to be made- They have re-calculated each time the document, or part of document modified.
- It can occur so many times( like thousands of ) per second