Photo by Hannah Tims on Unsplash
A while back I transitioned my web app to using REM units instead of the PX unit. This has a lot of benefits that I wonโt get into this article, but I did encounter a few conflicts I did not consider initially. react-window is a library that helps virtualize long lists!
This is super useful for rendering a considerably less amount of components/tags in the HTML to optimize the performance of the app. But, one thing to consider is that react-window expects certain parameters and properties to be specified in PX.
This article will quickly go over how I solved this problem.
react-window
React-window offers a component called FixedSizeList which can render out our list of components. The property we are most interested in is itemSize. This takes in the following:
Size of a item in the direction being windowed. For vertical lists, this is the row height. For horizontal lists, this is the column width.
However, the word size, in this case , refers specifically to pixels! What we have to do is convert our REM units to PX.
This is the small hook I created:
Implementing the hook
Letโs break down this hook into several parts. For sake of clarity, I named the variable itemSize inside the hook but can this can be done with an early return. First, we get the font size from the user with getComputedStyle, calling upon the document properties. Afterward, we multiply that amount with how we plan to convert the units from PX to REM.
This hook can just be directly called in the component with the necessary REM units/multiplier that may be necessary:
And that's it! Let me know if this hook was of any use to you or if you have any other preferred way to use REM units with react-window or any other library that specifically requires PX units.
More content at Relatable Code
Originally published at https://relatablecode.com on January 16, 2022.
Top comments (0)