I was working on my React investment calculator project (view project), and I was experiencing some lag time when it came to the project loading for large numbers. I was calculating what the investment had grown to by a certain age. The default age input was 65, but I noticed by accident that by typing in an extra number (e.g. “655”), the program took around 5 seconds to calculate the total. I thought this was strange since I figured it should only be running around 600 calculations, and that shouldn’t take anywhere near 5 seconds.
data:image/s3,"s3://crabby-images/0821d/0821d5052554f90973505120f10addff026bb90e" alt="Screenshot of investment calculator result"
data:image/s3,"s3://crabby-images/6d1b1/6d1b125091ba278503b11cbf9cbc8cfe759cc4a6" alt="Screenshot of investment calculator"
I realized that I was doing a couple things wrong in my program. For one, I had multiple setState()
functions inside of a useEffect()
. I didn’t need these there, since they did not need to run every when the parent component updated. It turned out that I didn’t need to use state for many of these variables at all, since several of them were calculated based on input variables. That is to say, I didn’t need to have an input variable getting set from state, and then have another state variable getting set from that initial input state. It was enough to just declare a normal variable in the component and let that run when the component updated.
data:image/s3,"s3://crabby-images/ec98a/ec98a4c2a92fb94e0721ca76073a59e21842bd9e" alt=""
I fixed this, but the program was still running slow. I was able to figure out that the other main problem was that a bar chart that I had set up using an NPM library was rendering slowly when the ending age was too high, probably because of the complexity of the SVG. I decided to solve this using a restriction on how high the final age could be.
data:image/s3,"s3://crabby-images/6b83b/6b83ba565b5cbd703eb0eb89d72d23ccba383cad" alt="Bar chart age v. earnings"
I wanted to share these thoughts that I went through while working on this project. I am still working on optimizing and finishing it up, but it has been lots of fun so far!