React Hook是React 16.8及更高版本引入的特性,它可以让你在函数组件中使用state以及其他的React特性。下面是6个常用的React Hook以及它们的用法和例子:
- useState
 
import React, { useState } from 'react';
 
function Example() {
  const [count, setCount] = useState(0);
 
  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}
- useEffect
 
import React, { useState, useEffect } from 'react';
 
function Example() {
  const [count, setCount] = useState(0);
 
  // 类似于类中的componentDidMount和componentDidUpdate:
  useEffect(() => {
    // 更新document的title
    document.title = `You clicked ${count} times`;
  });
 
  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}
- useContext
 
import React, { useContext } from 'react';
import { ThemeContext } from './ThemeContext';
 
function Button() {
  const theme = useContext(ThemeContext);
 
  return (
    <button style={{ backgroundColor: theme.background }}>
      I am styled by theme context!
    </button>
  );
}
- useReducer
 
import React, { useReducer } from 'react';
 
function Example() {
  const [state, dispatch] = useReducer(reducer, initialState);
 
  return (
    <div>
      <p>Count: {state.count}</p>
      <button onClick={() => dispatch({ type: 'increment' })}>
        Increment
      </button>
      <button onClick={() => dispatch({ type: 'decrement' })}>
        Decrement
      </button>
    </div>
  );
}
 
function reducer(state, action) {
  switch (action.type) {
    case 'increment':
      return { count: state.count + 1 };
    case 'decrement':
      return { count: state.count - 1 };
    default:
      throw new Error();
  }
}
- useCallback
 
import React, { useCallback } from 'react';
 
function Example() {
  const memoizedCallback = useCallback(() => {
    doSomething(a, b);
  }, [a, b]);
 
  return <SomeComponent onSomething={memoizedCallback} />;
}
- useMemo
 
import React, { useMemo } from 'react';
 
function Example() {
  const m