React hooks组件通信

简介: React hooks组件通信

一、前言


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


二、父子组件通信


1)父组件传值给子组件


子组件代码:


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

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

父组件代码

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

运行效果

d0ec9b167f5f460eba25649addfca44a.png

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}</>
}


运行效果


f92b222551ac4f908e0ad25ba8b0f4d7.png

目录
相关文章
|
SQL Java
如何使用阿里云短信服务实现登录页面,手机验证码登录?1
如何使用阿里云短信服务实现登录页面,手机验证码登录?
1221 0
|
前端开发 数据可视化 JavaScript
前端图形学实战: 从零开发一款轻量级滑动验证码组件(vue3 + vite版)
前端图形学实战: 从零开发一款轻量级滑动验证码组件(vue3 + vite版)
1734 0
|
Kubernetes 监控 调度
在 Kubernetes 中应该如何设置 CPU 的 requests 和 limits
在 Kubernetes 中应该如何设置 CPU 的 requests 和 limits
737 0
|
JavaScript 测试技术
【sgGoogleTranslate】自定义组件:基于Vue.js用谷歌Google Translate翻译插件实现网站多国语言开发
【sgGoogleTranslate】自定义组件:基于Vue.js用谷歌Google Translate翻译插件实现网站多国语言开发
|
资源调度 JavaScript Apache
Vue2使用echarts树图(tree)
这篇文章介绍了如何在Vue 3框架中集成echarts库来创建一个树状图(Tree Chart)组件,支持自定义数据和交互事件。
1212 0
Vue2使用echarts树图(tree)
|
存储 JavaScript 前端开发
使用JS创造一个3D粒子化星空,十分酷炫,大家快进来看看吧
使用JS创造一个3D粒子化星空,十分酷炫,大家快进来看看吧
|
机器学习/深度学习 存储 人工智能
【机器学习】Qwen1.5-14B-Chat大模型训练与推理实战
【机器学习】Qwen1.5-14B-Chat大模型训练与推理实战
2219 0
|
JavaScript API
uView Drawer 抽屉
uView Drawer 抽屉
383 0
|
缓存 安全 Java
Shiro框架的知识点一网打尽,生命不息,学习不止
Shiro框架的知识点一网打尽,生命不息,学习不止
379 0
|
前端开发
前端原生 CSS 跑马灯效果,无限轮播(横竖版本,带渐变遮罩,简单实用)
前端原生 CSS 跑马灯效果,无限轮播(横竖版本,带渐变遮罩,简单实用)
600 0