欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React數(shù)據(jù)傳遞的六種方式詳解

 更新時(shí)間:2025年08月14日 10:19:22   作者:江城開朗的豌豆  
在 React 應(yīng)用程序中,數(shù)據(jù)傳遞是非常重要的,它允許我們?cè)诮M件之間共享信息和狀態(tài),從而構(gòu)建出復(fù)雜的用戶界面,本文將深入探討React數(shù)據(jù)傳遞的六種方式,需要的朋友可以參考下

引言

“在 React 開發(fā)中,組件之間的數(shù)據(jù)傳遞就像現(xiàn)實(shí)中的聊天——父子組件可以直接對(duì)話,兄弟組件需要‘中介’,而跨層級(jí)組件可能得靠‘廣播’。今天,我就結(jié)合 6 年實(shí)戰(zhàn)經(jīng)驗(yàn),帶大家解鎖 React 組件通信的 6 種姿勢(shì),讓你徹底告別‘數(shù)據(jù)孤島’!”

1. 父子組件:props 直傳(最基礎(chǔ))

場(chǎng)景:父組件向子組件傳遞數(shù)據(jù)或函數(shù)。

// 父組件
const Parent = () => {
  const [message, setMessage] = useState("Hello from Parent!");

  return <Child greeting={message} />;
};

// 子組件
const Child = ({ greeting }) => {
  return <h1>{greeting}</h1>; // 直接使用父組件傳遞的 props
};

我的吐槽
“這就像老爸直接給兒子零花錢,簡(jiǎn)單粗暴,但兒子沒法主動(dòng)要錢(子組件不能反向傳數(shù)據(jù))。”

2. 子傳父:回調(diào)函數(shù)(Callback)

場(chǎng)景:子組件通過父組件傳遞的函數(shù)“逆向”通信。

// 父組件
const Parent = () => {
  const handleChildClick = (data) => {
    console.log("子組件說:", data); // 接收子組件數(shù)據(jù)
  };

  return <Child onClick={handleChildClick} />;
};

// 子組件
const Child = ({ onClick }) => {
  return <button onClick={() => onClick("I'm Child!")}>點(diǎn)我傳數(shù)據(jù)</button>;
};

我的心得
“這種方式適合簡(jiǎn)單的交互,比如表單提交。但如果層級(jí)太深,props 會(huì)變成‘擊鼓傳花’,代碼容易變亂。”

3. 兄弟組件:狀態(tài)提升(Lifting State Up)

場(chǎng)景:兩個(gè)兄弟組件共享父組件的狀態(tài)。

// 父組件
const Parent = () => {
  const [count, setCount] = useState(0);

  return (
    <>
      <SiblingA count={count} />
      <SiblingB onUpdate={() => setCount(count + 1)} />
    </>
  );
};

// 兄弟組件 A(顯示數(shù)據(jù))
const SiblingA = ({ count }) => <div>當(dāng)前計(jì)數(shù):{count}</div>;

// 兄弟組件 B(修改數(shù)據(jù))
const SiblingB = ({ onUpdate }) => <button onClick={onUpdate}>+1</button>;

我的比喻
“這就像兩兄弟共用老爸的支付寶賬號(hào)——花錢(SiblingB)和查余額(SiblingA)都得通過老爸(Parent)。”

4. 跨層級(jí)組件:Context API

場(chǎng)景:避免多層 props 透?jìng)?,?shí)現(xiàn)“隔代通信”。

// 創(chuàng)建 Context
const ThemeContext = createContext("light");

// 祖父組件
const Grandparent = () => {
  return (
    <ThemeContext.Provider value="dark">
      <Parent />
    </ThemeContext.Provider>
  );
};

// 孫子組件(跳過 Parent)
const Grandchild = () => {
  const theme = useContext(ThemeContext);
  return <div>當(dāng)前主題:{theme}</div>; // 直接拿到祖父的數(shù)據(jù)
};

我的提醒
“Context 適合全局主題、用戶信息等低頻更新數(shù)據(jù)。頻繁更新的值用 Context 可能導(dǎo)致性能問題!”

5. 任意組件:事件總線(Event Bus)

場(chǎng)景:完全不相關(guān)的組件間通信,類似“廣播”。

// 事件總線(可以用 mitt 或自定義)
const eventBus = new EventEmitter();

// 組件 A(發(fā)布事件)
const ComponentA = () => {
  const emitEvent = () => eventBus.emit("alert", "我是組件A發(fā)的消息!");
  return <button onClick={emitEvent}>發(fā)布事件</button>;
};

// 組件 B(訂閱事件)
const ComponentB = () => {
  const [message, setMessage] = useState("");

  useEffect(() => {
    eventBus.on("alert", setMessage);
    return () => eventBus.off("alert", setMessage);
  }, []);

  return <div>收到消息:{message}</div>;
};

我的警告
“事件總線雖然靈活,但容易導(dǎo)致代碼難以維護(hù)。慎用,除非你真的需要‘廣播’!”

6. 全局狀態(tài)管理:Redux / Zustand

場(chǎng)景:復(fù)雜應(yīng)用需要集中管理狀態(tài)。

// 以 Zustand 為例
import { create } from "zustand";

// 創(chuàng)建 store
const useStore = create((set) => ({
  user: null,
  login: (name) => set({ user: name }),
}));

// 組件 A(修改狀態(tài))
const ComponentA = () => {
  const login = useStore((state) => state.login);
  return <button onClick={() => login("小楊")}>登錄</button>;
};

// 組件 B(讀取狀態(tài))
const ComponentB = () => {
  const user = useStore((state) => state.user);
  return <div>當(dāng)前用戶:{user || "未登錄"}</div>;
};

我的選擇
“Redux 適合大型項(xiàng)目,但學(xué)習(xí)成本高。個(gè)人更推薦 Zustand,API 簡(jiǎn)單,夠用!”

寫在最后?

到此這篇關(guān)于React數(shù)據(jù)傳遞的六種方式詳解的文章就介紹到這了,更多相關(guān)React數(shù)據(jù)傳遞內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • webpack+react+antd腳手架優(yōu)化的方法

    webpack+react+antd腳手架優(yōu)化的方法

    本篇文章主要介紹了webpack+react+antd腳手架優(yōu)化的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • React??memo允許你的組件在?props?沒有改變的情況下跳過重新渲染的問題記錄

    React??memo允許你的組件在?props?沒有改變的情況下跳過重新渲染的問題記錄

    使用?memo?將組件包裝起來,以獲得該組件的一個(gè)?記憶化?版本,只要該組件的?props?沒有改變,這個(gè)記憶化版本就不會(huì)在其父組件重新渲染時(shí)重新渲染,這篇文章主要介紹了React??memo允許你的組件在?props?沒有改變的情況下跳過重新渲染,需要的朋友可以參考下
    2024-06-06
  • react 應(yīng)用多入口配置及實(shí)踐總結(jié)

    react 應(yīng)用多入口配置及實(shí)踐總結(jié)

    這篇文章主要介紹了react 應(yīng)用多入口配置及實(shí)踐總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10
  • 詳解React?如何防止?XSS?攻擊論$$typeof?的作用

    詳解React?如何防止?XSS?攻擊論$$typeof?的作用

    這篇文章主要介紹了詳解React?如何防止?XSS?攻擊論$$typeof?的作用,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • react-router中Link標(biāo)簽和a標(biāo)簽有什么區(qū)別

    react-router中Link標(biāo)簽和a標(biāo)簽有什么區(qū)別

    本文主要介紹了react-router中Link標(biāo)簽和a標(biāo)簽有什么區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • React 遠(yuǎn)程動(dòng)態(tài)組件實(shí)踐示例詳解

    React 遠(yuǎn)程動(dòng)態(tài)組件實(shí)踐示例詳解

    這篇文章主要為大家介紹了React 遠(yuǎn)程動(dòng)態(tài)組件實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • React 原理詳解

    React 原理詳解

    這篇文章主要介紹了深入理解react的原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-10-10
  • 深入淺析React refs的簡(jiǎn)介

    深入淺析React refs的簡(jiǎn)介

    React中的Refs提供了一種方式,允許我們?cè)L問DOM節(jié)點(diǎn)或在render方法中創(chuàng)建的React元素,本文給大家介紹react refs的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2021-07-07
  • React中useEffect原理的代碼簡(jiǎn)單實(shí)現(xiàn)詳解

    React中useEffect原理的代碼簡(jiǎn)單實(shí)現(xiàn)詳解

    React的useEffect鉤子是React函數(shù)組件中處理副作用,本文將通過一個(gè)簡(jiǎn)單的例子解釋如何用代碼實(shí)現(xiàn)useEffect的基本原理,感興趣的小伙伴可以了解下
    2023-12-12
  • React如何使用錯(cuò)誤邊界(Error Boundaries)捕獲組件錯(cuò)誤

    React如何使用錯(cuò)誤邊界(Error Boundaries)捕獲組件錯(cuò)誤

    在 React 里,錯(cuò)誤邊界就像是一個(gè)“小衛(wèi)士”,專門負(fù)責(zé)在組件出現(xiàn)錯(cuò)誤時(shí)挺身而出,避免整個(gè)應(yīng)用因?yàn)橐粋€(gè)小錯(cuò)誤就崩潰掉,下面小編就來為大家介紹一下如何利用它捕獲組件錯(cuò)誤吧
    2025-03-03

最新評(píng)論