我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解React hooks组件通信方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解React hooks组件通信方法

一、前言

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

二、父子组件通信

1)父组件传值给子组件

子组件代码:

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

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

父组件代码

//父组件
const Parent = () => {
  return <Child //子组件
    params1="1"
    params2="2"
  />
}

运行效果

2)子组件传值给父组件

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

首先需要导入对应的模块包useImperativeHandleuseRef,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 <>父组件传递的参数:{param1},{param2}</>
}

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

在项目目录创建一个context.js文件用于创建我们的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 <>父组件传递的参数:{param1},{param2}</>
}

运行效果

到此这篇关于React hooks组件通信的文章就介绍到这了,更多相关React hooks组件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解React hooks组件通信方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

React组件通信实现方式详解

这篇文章主要介绍了React组件通信,在开发中组件通信是React中的一个重要的知识点,本文通过实例代码给大家讲解react中常用的父子、跨组件通信的方法,需要的朋友可以参考下
2023-03-19

React组件间通信的方法有哪些

这篇文章给大家分享的是有关React组件间通信的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、父子组件通信原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件通过回调事件与
2023-06-25

hooks写React组件的5个注意细节详解

这篇文章主要为大家介绍了hooks写React组件的5个需要注意的细节详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-13

Vue组件的通信方式详解

这篇文章主要介绍的是Vue组件间的通信方式,本文将系统的介绍了几种不使用Vuex,比较实用的组件间的通信方式,希望能帮助到大家
2023-05-15

React组件间通信方式有哪些

这篇文章主要介绍React组件间通信方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!组件间通信方式总结父组件 => 子组件:PropsInstance Methods子组件 => 父组件:Callback F
2023-06-06

Vue3组件间的通信方式详解

这篇文章主要介绍了Vue3组件间的通信方式,在使用vue时,我们经常会把不同的模块拆分成不同的组件,而组件之间有的需要传递数据,所以组件间的数据通信就非常重要了
2023-05-17

编程热搜

目录