The reason behind this is that whenever you component’s props changes, the framework re-renders it in the DOM with the new props. Even though React updates the DOM based on DIff mechanism there are cases when the child gets updated when the parent is updated.
The Framework provides a lifecycle method that can help you avoid re-rendering of components in unwanted scenarios. The method shouldComponentUpdate
is called whenever you update the state of the component.
Based on the value it returns the framework depending upon whether to update the component and re-render or simply skip the re-rendering part.
A Common Scenario
A very common scenario of this case is when you have a common button component with two pros one is the button caption and a function for onclick handler.
Here, the button component is re-rendered only when the props or the state of the button changes. But by default the component is re-rendered every time the parent component it updated and rendered.
In order to avoid this case we simply add a shouldComponentUpdate
and check if the props change and then return the Boolean value.
Thus, now only when the prop caption is changed by the parent component, the button gets updated.
This improves the performance in a large scale application where you have lot of nested components in which most of the components are almost static like the above mentioned button.
There’s a lot more stuff that we can help you crack in React/React Native - we’ll come back to you with a lot more tips and tricks and you’ll have an award-winning project at the end!
Subscribe to our newsletter
Get the latest updates from our team delivered directly to your inbox.
Related Posts
10 Gems in Ruby that you will love
Let's go back to basics with Ruby on Rails and see some of the Gems that we use everyday at skcript. #StartWithSkcript
#100DaysOfCommits
Our CTO, Swaathi, talks about our commitment to the #100DaysOfCommit challenge. Join us.
18 Python packages you should be using right now
Let us look at some python packages that will get you started on your machine learning path #StartWithSkcript