()
| 3 | // 方式1:App提取 bailout四要素 |
| 4 | // 方式2:ExpensiveSubtree用memo包裹 |
| 5 | export default function App() { |
| 6 | const [num, update] = useState(0); |
| 7 | console.log('App render ', num); |
| 8 | |
| 9 | const Cpn = useMemo(() => <ExpensiveSubtree />, []); |
| 10 | |
| 11 | return ( |
| 12 | <div onClick={() => update(num + 100)}> |
| 13 | <p>num is: {num}</p> |
| 14 | {Cpn} |
| 15 | </div> |
| 16 | ); |
| 17 | } |
| 18 | |
| 19 | function ExpensiveSubtree() { |
| 20 | console.log('ExpensiveSubtree render'); |