React hooks组件通信

x33g5p2x  于2022-08-17 转载在 其他  
字(1.8k)|赞(0)|评价(0)|浏览(579)

一、前言

组件通信是React中的一个重要的知识点,下面列举一下 react hooks中常用的父子、跨组件通信的方法

二、父子组件通信

1)父组件传值给子组件

子组件代码:

  1. //子组件
  2. const Child = ({ param1, param2 }) => {
  3. return <>父组件传递的参数:{param1},{param2}</>
  4. }

param1param2 为子组件接收父组件的传参,父组件代码如下:

父组件代码

  1. //父组件
  2. const Parent = () => {
  3. return <Child //子组件
  4. params1="1"
  5. params2="2"
  6. />
  7. }

运行效果

2)子组件传值给父组件

子传父严格来讲还是父传子,父组件传递给子组件ref,子组件将想要暴露给父组件的值放在上面,然后父组件就可以使用其值:

首先需要导入对应的模块包useImperativeHandleuseRef,forwardRef

  1. import React, { useRef, useImperativeHandle, useEffect, forwardRef } from 'react';

父组件代码

  1. //父组件
  2. const Parent = () => {//父组件
  3. const ref = useRef(); //ref
  4. useEffect(() => {
  5. console.log(ref)
  6. }, [])
  7. return (
  8. <Child //子组件
  9. ref={ref} //将ref传递给子组件
  10. />)
  11. }

子组件代码

  1. //子组件
  2. const Child = forwardRef(({ },ref) => {
  3. useImperativeHandle(ref, () => ({
  4. data: '我是子组件'
  5. }));
  6. return <>我是子组件</>
  7. })

运行后控制台输出

  1. {
  2. "current": {
  3. "data": "我是子组件"
  4. }
  5. }

3)跨组件传值(父传孙子组件)

跨组件传值我们页可以使用最开始介绍的父传子的方法,一层层的嵌套传递,例如:

  1. const Parent = () => {
  2. return <Child1 //子组件
  3. param1="1"
  4. param2="2"
  5. />
  6. }
  7. //子组件
  8. const Child1 = ({ param1, param2 }) => {
  9. return <Child2 param1={param1} param2={param2} />
  10. }
  11. //子子组件
  12. const Child2 = ({ param1, param2 }) => {
  13. return <>父组件传递的参数:{param1},{param2}</>
  14. }

但如果有更多层嵌套时,一层层的传递会显得很冗余和麻烦,所以我们可以使用context来解决这个问题。

在项目目录创建一个context.js文件用于创建我们的context,代码如下:

  1. import { createContext } from 'react'
  2. const myContext = createContext(null)
  3. export default myContext

然后在我们组件文件中引入我们定义的myContext,并引入react对应包:

  1. import React, { useContext } from 'react';
  2. import myContext from './context'

父组件代码

  1. const Parent = () => {
  2. //使用Provider传递值
  3. return <myContext.Provider value={{ param1: "1", param2: "2" }}>
  4. <Child1 />
  5. </myContext.Provider>
  6. }

子组件和子子组件代码

  1. //子组件无需改动
  2. const Child1 = () => {
  3. return <Child2 />
  4. }
  5. //子子组件
  6. const Child2 = () => {
  7. //通过useContext获取父组件的值
  8. const { param1, param2 } = useContext(myContext)
  9. return <>父组件传递的参数:{param1},{param2}</>
  10. }

运行效果

相关文章