๐ข Memoization
Information
In Angular, pure Pipes are very powerful because the value is memoized, which means if the input value doesnโt change, the transform
function of the pipe is not recomputed, and the cached value is outputted.
You can learn more about pipes in the Angular documentation and inside this deep dive article.
In this challenge, we start with a button to load a list of people. Each person is associated with a number, and we will use the Fibonacci calculation to create a heavy computation that will slow down the application.
Once the list is loaded, try typing some letters inside the input field. You will notice that the application is very slow, even though you are only performing very basic typing.
Letโs use the Angular DevTool to profile our application and understand how this tool can help us understand what is happening inside our application.
Now, start profiling your application and type some letters inside the input field. You will see some red bars showing up inside the profiler panel.
If you click on one of the bars (indicated by the yellow arrow in the picture below), you will see that the change detection cycle is taking more than 3s in PersonListComponent
.
Statement
The goal of this challenge is to understand what is causing this latency and to improve it.
Hints:
Hint 1
Use Pipes
to memoize the Fibonacci computation.