詳解React?hooks組件通信方法
一、前言
組件通信是React中的一個重要的知識點,下面列舉一下 react hooks中常用的父子、跨組件通信的方法
二、父子組件通信
1)父組件傳值給子組件
子組件代碼:
//子組件
const Child = ({ param1, param2 }) => {
return <>父組件傳遞的參數(shù):{param1},{param2}</>
}param1、param2 為子組件接收父組件的傳參,父組件代碼如下:
父組件代碼
//父組件
const Parent = () => {
return <Child //子組件
params1="1"
params2="2"
/>
}運行效果

2)子組件傳值給父組件
子傳父嚴格來講還是父傳子,父組件傳遞給子組件ref,子組件將想要暴露給父組件的值放在上面,然后父組件就可以使用其值:
首先需要導入對應的模塊包useImperativeHandle、useRef,forwardRef :
import React, { useRef, useImperativeHandle, useEffect, forwardRef } from 'react';父組件代碼
//父組件
const Parent = () => {//父組件
const ref = useRef(); //ref
useEffect(() => {
console.log(ref)
}, [])
return (
<Child //子組件
ref={ref} //將ref傳遞給子組件
/>)
}
子組件代碼
//子組件
const Child = forwardRef(({ },ref) => {
useImperativeHandle(ref, () => ({
data: '我是子組件'
}));
return <>我是子組件</>
})
運行后控制臺輸出
{
"current": {
"data": "我是子組件"
}
}
3)跨組件傳值(父傳孫子組件)
跨組件傳值我們頁可以使用最開始介紹的父傳子的方法,一層層的嵌套傳遞,例如:
const Parent = () => {
return <Child1 //子組件
param1="1"
param2="2"
/>
}
//子組件
const Child1 = ({ param1, param2 }) => {
return <Child2 param1={param1} param2={param2} />
}
//子子組件
const Child2 = ({ param1, param2 }) => {
return <>父組件傳遞的參數(shù):{param1},{param2}</>
}
但如果有更多層嵌套時,一層層的傳遞會顯得很冗余和麻煩,所以我們可以使用context來解決這個問題。
在項目目錄創(chuàng)建一個context.js文件用于創(chuàng)建我們的context,代碼如下:
import { createContext } from 'react'
const myContext = createContext(null)
export default myContext
然后在我們組件文件中引入我們定義的myContext,并引入react對應包:
import React, { useContext } from 'react';
import myContext from './context'
父組件代碼
const Parent = () => {
//使用Provider傳遞值
return <myContext.Provider value={{ param1: "1", param2: "2" }}>
<Child1 />
</myContext.Provider>
}
子組件和子子組件代碼
//子組件無需改動
const Child1 = () => {
return <Child2 />
}
//子子組件
const Child2 = () => {
//通過useContext獲取父組件的值
const { param1, param2 } = useContext(myContext)
return <>父組件傳遞的參數(shù):{param1},{param2}</>
}
運行效果

到此這篇關于React hooks組件通信的文章就介紹到這了,更多相關React hooks組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
React函數(shù)組件useContext useReducer自定義hooks
這篇文章主要為大家介紹了React函數(shù)組件useContext useReducer自定義hooks示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08
React?Hook?Form?優(yōu)雅處理表單使用指南
這篇文章主要為大家介紹了React?Hook?Form?優(yōu)雅處理表單使用指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03
react-native 配置@符號絕對路徑配置和絕對路徑?jīng)]有提示的問題
本文主要介紹了react-native 配置@符號絕對路徑配置和絕對路徑?jīng)]有提示的問題,文中通過圖文示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-01-01
用react實現(xiàn)一個簡單的scrollView組件
這篇文章主要給大家介紹一下如何用 react 實現(xiàn)一個簡單的 scrollView組件,文中有詳細的代碼示例,具有一定的參考價值,需要的朋友可以參考下2023-07-07

