what is react state machine

coldplay.xixi
Release: 2020-11-27 11:05:30
Original
1820 people have browsed it

React regards the component as a state machine, realizes different states through interaction with the user, and then renders the UI to keep the user interface and data consistent.

what is react state machine

React treats components as aState Machine(State Machines). By interacting with the user, different states are achieved, and then the UI is rendered to keep the user interface and data consistent.

In React, you only need to update the component's state, and then re-render the user interface based on the new state (without manipulating the DOM).

In applications with many components, it is very important to release the resources occupied by the components upon destruction.

Every time the Clock component is loaded into the DOM for the first time, we want to generate a timer, which is called mounting in React.

Similarly, whenever the DOM generated by Clock is removed, we will also want to clear the timer, which is called unloading in React.

    Hello React!    
Copy after login

Analysis:

componentDidMount()andcomponentWillUnmount()methods are called life cycle hooks.

After the component is output to the DOM, thecomponentDidMount()hook will be executed, and we can set a timer on this hook.

this.timerID is the ID of the timer. We can uninstall the timer in the componentWillUnmount() hook.

React calls the Clock component's constructor when is passed toReactDOM.render(). Since Clock needs to display the current time, this.state is initialized with an object containing the current time. We will update this status later.

React then calls therender()method of the Clock component. This is React understanding what should be on the screen, and then React updates the DOM to match the Clock's rendered output.

When Clock's output is inserted into the DOM, React calls the componentDidMount() lifecycle hook. In it, the Clock component requires the browser to set a timer and call tick() every second.

The browser calls thetick()method every second. In it, the Clock component schedules UI updates by calling setState() with an object containing the current time. By calling setState() , React knows that the state has changed and calls the render() method again to determine what should be displayed on the screen. This time, thethis.state.datein the render() method will be different, so the rendered output will contain the updated time, and the DOM will be updated accordingly.

Once the Clock component is removed from the DOM, React will call the componentWillUnmount() hook function and the timer will be cleared.

Related learning recommendations:javascript learning tutorial

The above is the detailed content of what is react state machine. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!