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