I haven’t touched functional components for a long time. Now I want to summarize and review them. I plan to use functional components after this review.

Why not class

The Class component has its advantages, such as template dumb-ass, which is easy to learn and the lifecycle is built in ahead of time. But there are still many shortcomings

  • Difficult to reuse state logic: It is difficult to reuse state logic between components, perhaps using render props or HOC, but both render properties and higher-order components have a parent container (usually div elements) wrapped around the original component, resulting in hierarchical redundancy

  • Tends to be complex and difficult to maintain:

Mixing irrelevant logic in life cycle functions (registering events and other logic in componentDidMount, unmounting events in componentWillUnmount)

Class components have access to and processing of state all over the place, making components difficult to break down into smaller components

  • This points to the problem: when a parent passes a function to a child, this must be bound

So can these deficiencies be addressed? Yes, use functional components

const Hello = (props) = > {
return <div>{props.message}</div>
}
Copy the code

However, functional components lack state and life cycle compared to class components.

God said let there be light, and there was light

React 16.8.0 introduces hooks API, where useState fixes the lack of state

const App = props= > {
  const [n,setN] = useState(0) //n is read, setN is write, and 0 is the initial value of n
  const onClick = () = > {
    setN(n + 1)}return (
    <div>
      {n}
      <button onClick = {onClick} >+ 1</button>
    </div>)}Copy the code

UseEffect in the hooks API addresses the problem of no lifecycle

  • Function components are executed as constructors
  • Simulation componentDidMount
useEffect(() = >{ console.log('First render') },[])
Copy the code
  • Simulation componentDidUpdate
useEffect(() = >{ console.log('Any property change')})
useEffect(() = >{ console.log('n changed')}, [n])
Copy the code
  • Simulation componentWillUnmount
useEffect(() = >{
console.log('First render')
return () = >{
console.log('Component is going to hang')}})Copy the code
  • Simulation shouldComponentUpdate

React.memo and useMemo

  • To simulate the render

The return value of the function component is the return value of render

So functional components can not only avoid many of the drawbacks of class components, but also provide more flexibility and freedom, so they are a good alternative

The next section is intended to take a good look at each hooks API