react里組件通信的幾種方式小結(jié)
1. props傳遞(父向子通信):
- 說明: 父組件通過
props屬性向子組件傳遞數(shù)據(jù)。 - 如何進(jìn)行: 在父組件中定義子組件時(shí),通過屬性名將值傳給子組件,子組件通過
this.props接收。
// 父組件
import ChildProps from "./ChildProps";
function ParentProps() {
const message = "我是父組件";
return <ChildProps message={message} />;
}
export default ParentProps;
// 子組件
function ChildProps(props: any) {
return (<div>
<span>{props.message}</span>
<br />
<span>我是子組件</span>
</div>);
}
export default ChildProps;

2. 回調(diào)函數(shù)作為props(子向父通信):
- 說明: 子組件通過調(diào)用父組件傳遞的回調(diào)函數(shù),將信息傳回給父組件。
- 如何進(jìn)行: 父組件定義一個(gè)方法,將其作為
prop傳遞給子組件;子組件在適當(dāng)?shù)臅r(shí)候調(diào)用這個(gè)函數(shù),傳遞數(shù)據(jù)或事件信息。
// 父組件
import ChildrenEmit from "./ChildrenEmit";
function ParentEmit() {
const handleButtonClick = (value: string) => {
console.log(value, "ParentEmit: handleButtonClick");
};
return (
<div>
<ChildrenEmit onButtonClick={handleButtonClick}></ChildrenEmit>
</div>
);
}
export default ParentEmit;
// 子組件
function ChildrenEmit (props: { onButtonClick: (arg0: string) => void; }) {
return (
<button onClick={() => props.onButtonClick('按鈕被點(diǎn)擊了~')}>
點(diǎn)擊
</button>
)
}
export default ChildrenEmit;

3. Context API:
- 說明: 方式:
React提供了一個(gè)Context API,允許你在組件樹中傳遞數(shù)據(jù),而無需手動(dòng)逐層傳遞props。 - 如何使用:創(chuàng)建一個(gè)
Context,使用React.createContext();在最頂層的組件中使用<MyContext.Provider value={value}>包裹需要共享狀態(tài)的組件樹;在消費(fèi)組件中使用<MyContext.Consumer>或useContext(MyContext)來訪問上下文中的值。
// MyContext.ts
// 創(chuàng)建Context
import { createContext } from "react";
export const MyContext = createContext('red');
// ParentContext.tsx
// 父組件
import { useContext } from "react";
import { MyContext } from "./MyContext";
import ChildrenContext from "./ChildrenContext";
const ParentContext = () => {
const contextValue = useContext(MyContext);
return (
<MyContext.Provider value={contextValue}>
<ChildrenContext />
</MyContext.Provider>
);
};
export default ParentContext;
// ChildrenContext.tsx
// 子組件
import { useContext } from "react";
import { MyContext } from "./MyContext";
import GrandsonContext from "./GrandsonContext";
const ChildrenContext = () => {
const contentValue = useContext(MyContext);
return (
<div>
<div>子組件顏色: {contentValue}</div>
<GrandsonContext></GrandsonContext>
</div>
);
};
export default ChildrenContext;
// GrandsonContext.tsx
// 孫組件
import { useContext } from "react";
import { MyContext } from "./MyContext";
import GranddaughterContext from "./GranddaughterContext";
const GrandsonContext = () => {
const contentValue = useContext(MyContext);
return (
<div>
<div>孫組件1顏色: {contentValue}</div>
<GranddaughterContext></GranddaughterContext>
</div>
);
};
export default GrandsonContext;
// GranddaughterContext.tsx
// 孫組件
import { useContext } from "react";
import { MyContext } from "./MyContext";
const GranddaughterContext = () => {
const contentValue = useContext(MyContext);
return (
<div>
<div>孫組件2顏色:{contentValue}</div>
</div>
);
};
export default GranddaughterContext;

4. Redux或MobX等狀態(tài)管理庫:
- 方式:適用于大型應(yīng)用,通過將狀態(tài)提升到一個(gè)單一的
store中管理,任何組件都可以訪問和修改store中的狀態(tài)。 - 如何使用:引入相應(yīng)的庫并設(shè)置
store,使用Provider組件將store包裹在應(yīng)用的最外層,組件內(nèi)部通過connect函數(shù)(Redux)或Observer(MobX)等與store連接,從而獲取或改變狀態(tài)。
4.1 Redux使用示例
這個(gè)例子展示了如何創(chuàng)建一個(gè)簡(jiǎn)單的計(jì)數(shù)器應(yīng)用,通過Redux管理狀態(tài)。用戶點(diǎn)擊加減按鈕時(shí),會(huì)觸發(fā)actions,然后通過reducer更新state,最終React組件根據(jù)新的state重新渲染。
- 安裝
redux和 和react-redux庫。
npm install redux react-redux
- 創(chuàng)建 Action
// actions.ts
export const increment = () => {
return { type: 'INCREMENT' };
};
export const decrement = () => {
return { type: 'DECREMENT' };
};
- 創(chuàng)建
reducer
// reducer.ts
const initialState = { count: 0 };
function counterReducer(state = initialState, action: { type: any; }) {
switch (action.type) {
case 'INCREMENT':
return { ...state, count: state.count + 1 };
case 'DECREMENT':
return { ...state, count: state.count - 1 };
default:
return state;
}
}
export default counterReducer;
- 創(chuàng)建
store
// store.ts
import { createStore } from 'redux';
import counterReducer from './reducer';
const store = createStore(counterReducer);
export default store;
- 創(chuàng)建組件使用
import { connect } from 'react-redux';
import { increment, decrement } from './actions';
import { ReactElement, JSXElementConstructor, ReactNode, ReactPortal, MouseEventHandler } from 'react';
function ParentRedux(props: { count: string | number | boolean | ReactElement<any, string | JSXElementConstructor<any>> | Iterable<ReactNode> | ReactPortal | null | undefined; onIncrement: MouseEventHandler<HTMLButtonElement> | undefined; onDecrement: MouseEventHandler<HTMLButtonElement> | undefined; }) {
return (
<div>
<h1>Counter: {props.count}</h1>
<button onClick={props.onIncrement}>+</button>
<button onClick={props.onDecrement}>-</button>
</div>
);
}
const mapStateToProps = (state: { count: any; }) => ({
count: state.count,
});
const mapDispatchToProps = (dispatch: (arg0: { type: string; }) => any) => ({
onIncrement: () => dispatch(increment()),
onDecrement: () => dispatch(decrement()),
});
export default connect(mapStateToProps, mapDispatchToProps)(ParentRedux);
- 根組件導(dǎo)入
import React from "react";
import "./App.css";
import { Provider } from 'react-redux';
import store from './page/redux/store';
import ParentProps from "./page/props/ParentProps";
import ParentEmit from "./page/emit/ParentEmit";
import ParentContext from "./page/context/ParentContext";
import ParentRefs from "./page/refs/ParentRefs";
import ParentRedux from "./page/redux/ParentRedux";
function App() {
return (
<div className="App">
<div className="App-item">
測(cè)試父子傳參:<ParentProps></ParentProps>
</div>
<div className="App-item">
測(cè)試子傳父:<ParentEmit></ParentEmit>
</div>
<div className="App-item">
測(cè)試context傳參:<ParentContext></ParentContext>
</div>
<div className="App-item">
測(cè)試refs傳參:<ParentRefs></ParentRefs>
</div>
<Provider store={store}>
<div className="App-item">
測(cè)試redux傳參:<ParentRedux></ParentRedux>
</div>
</Provider>
</div>
);
}
export default App;

這個(gè)例子展示了如何創(chuàng)建一個(gè)簡(jiǎn)單的計(jì)數(shù)器應(yīng)用,通過
Redux管理狀態(tài)。用戶點(diǎn)擊加減按鈕時(shí),會(huì)觸發(fā)actions,然后通過reducer更新state,最終React組件根據(jù)新的state重新渲染。
5. refs:
- 方式:主要用于訪問
DOM元素或在組件之間傳遞一個(gè)可變的引用。 - 如何使用:可以通過
React.createRef()創(chuàng)建ref,然后將其附加到特定的React元素上。在組件中,可以通過this.myRef.current訪問DOM元素或在類組件間傳遞ref以直接操作另一個(gè)組件的實(shí)例。
// ParentRefs.tsx
// 父組件
import { useRef } from "react";
import ChildRefs from "./ChildRefs";
const ParentRefs = () => {
const childRef = useRef<HTMLInputElement>(null);
const handleClick = (): void => {
childRef?.current?.focus();
};
return (
<>
<ChildRefs ref={childRef} />
<button onClick={handleClick}>Focus Child Input</button>
</>
);
};
export default ParentRefs;
// ChildRefs.tsx
// 子組件
import { forwardRef } from 'react';
const ChildRefs = forwardRef<HTMLInputElement>((props, ref) => {
return (
<div>
<input type="text" ref={ref} />
</div>
);
});
export default ChildRefs;到此這篇關(guān)于react里組件通信的幾種方式小結(jié)的文章就介紹到這了,更多相關(guān)react組件通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用vue-router beforEach實(shí)現(xiàn)判斷用戶登錄跳轉(zhuǎn)路由篩選功能
這篇文章主要介紹了vue使用vue-router beforEach實(shí)現(xiàn)判斷用戶登錄跳轉(zhuǎn)路由篩選,本篇文章默認(rèn)您已經(jīng)會(huì)使用 webpack 或者 vue-cli 來進(jìn)行環(huán)境的搭建,并且具有一定的vue基礎(chǔ)。需要的朋友可以參考下2018-06-06
Vue-router中hash模式與history模式的區(qū)別詳解
這篇文章主要給大家介紹了關(guān)于Vue-router中hash模式與history模式區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
Vue如何獲取new Date().getTime()時(shí)間戳
在Web開發(fā)中,前端使用Vue.js獲取的是毫秒級(jí)時(shí)間戳,而PHP后端則是秒級(jí)時(shí)間戳,處理此類問題時(shí),需要將PHP的時(shí)間戳乘以1000轉(zhuǎn)換為毫秒級(jí),以保證數(shù)據(jù)的一致性和正確的邏輯判斷2024-10-10
vue.js?Table?組件自定義列寬實(shí)現(xiàn)核心方法
這篇文章主要介紹了vue.js?Table?組件自定義列寬實(shí)現(xiàn)核心方法,文圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07

