当前位置:首页 > React

react函数组件如何更新

2026-03-11 10:59:54React

使用 State Hook 更新组件

React 函数组件通过 useState Hook 管理状态。调用状态更新函数会触发组件重新渲染。

import { useState } from 'react';

function Counter() {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={() => setCount(count + 1)}>Increment</button>
    </div>
  );
}

使用 Effect Hook 处理副作用

useEffect Hook 用于在组件渲染后执行副作用操作(如数据获取、订阅等)。依赖项数组控制副作用的触发时机。

import { useState, useEffect } from 'react';

function DataFetcher() {
  const [data, setData] = useState(null);

  useEffect(() => {
    fetch('https://api.example.com/data')
      .then(response => response.json())
      .then(data => setData(data));
  }, []); // 空数组表示仅在组件挂载时执行
}

使用 Context 跨组件更新

通过 useContext Hook 访问 Context 数据,Context 值变化会触发依赖该 Context 的组件更新。

import { createContext, useContext } from 'react';

const ThemeContext = createContext('light');

function ThemedButton() {
  const theme = useContext(ThemeContext);
  return <button style={{ background: theme === 'dark' ? '#333' : '#eee' }}>Click</button>;
}

使用 useReducer 管理复杂状态

useReducer 适用于状态逻辑较复杂的场景,通过 dispatch 动作更新状态。

import { useReducer } from 'react';

function reducer(state, action) {
  switch (action.type) {
    case 'increment':
      return { count: state.count + 1 };
    default:
      throw new Error();
  }
}

function Counter() {
  const [state, dispatch] = useReducer(reducer, { count: 0 });

  return (
    <div>
      <p>Count: {state.count}</p>
      <button onClick={() => dispatch({ type: 'increment' })}>Increment</button>
    </div>
  );
}

使用 useCallback 和 useMemo 优化性能

useCallback 缓存回调函数,useMemo 缓存计算结果,避免不必要的重新渲染。

react函数组件如何更新

import { useCallback, useMemo } from 'react';

function OptimizedComponent({ items }) {
  const handleClick = useCallback(() => {
    console.log('Item clicked');
  }, []);

  const filteredItems = useMemo(() => {
    return items.filter(item => item.active);
  }, [items]);

  return <List items={filteredItems} onClick={handleClick} />;
}

标签: 函数组件
分享给朋友:

相关文章

Vue函数实现

Vue函数实现

Vue 函数式组件的实现 Vue 函数式组件是一种无状态、无实例的组件形式,适用于简单渲染逻辑的场景。其核心特点是性能高效,适合纯展示型需求。 定义方式 export default { fu…

vue实现下拉框组件

vue实现下拉框组件

Vue 下拉框组件实现 基础实现 创建基础下拉框组件,使用v-model实现双向数据绑定: <template> <div class="dropdown"> &…

uniapp组件

uniapp组件

uniapp组件基础概念 uniapp的组件系统基于Vue.js,支持跨平台开发(H5、小程序、App等)。组件分为内置基础组件(如<view>、<button>)和自定义组件…

react组件如何通讯

react组件如何通讯

React 组件通讯方式 React 组件间的通讯方式主要包括以下几种方法,适用于不同场景下的数据传递和状态管理需求。 父子组件通讯(Props 传递) 父组件通过 props 向子组件传递数据或回…

uniapp 分页组件

uniapp 分页组件

uniapp 分页组件实现方法 在uniapp中实现分页功能,可以通过自定义组件或使用第三方组件库完成。以下是几种常见实现方式: 自定义分页组件 创建一个名为uni-pagination的组件,模板…

vue实现盖章组件

vue实现盖章组件

实现Vue盖章组件的步骤 组件结构设计 创建一个Vue组件,包含画布元素和必要的控制按钮。画布用于显示盖章效果,按钮用于触发盖章操作。组件需要接收图片和盖章位置等参数。 <template&g…