IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React Hooks父子组件,祖孙组件常用通信之奶妈教程 -> 正文阅读

[JavaScript知识库]React Hooks父子组件,祖孙组件常用通信之奶妈教程

React 组件间通信常用的大概有这么几种方式:

首先准备三个组件,他们之间的关系是:根组件 》 父组件 》 子组件

如下目录结构:
在这里插入图片描述

创建三个组件文件,并展示最终效果图:

在这里插入图片描述

父组件向子组件通信(props):

创建父组件

import React, { useState, createContext } from 'react';
import './App.css';

// 引入父组件
import Parent from './page/parent'

const App = () => {

  const msg = '1111'
  const [propsMsg, setPropsMsg] = useState('这是我要传递的参数');

  return (
    <div className="App">
      <div className='gen'>
        <h1>根组件</h1>
        <p>参数:{propsMsg}</p>
        
        // 这里是重点!!!
        // 开始向子组件传递参数 msg
        <Parent msg={propsMsg} />
        
      </div>
    </div>
  );
}

export default App;

创建子组件

import React, {useState, useEffect} from 'react';

const Parent = (props) => {

    // 接收从父组件传递进来的数据
    const { msg } = props;
    
    return (
        <div className="parent">
            <h2>这是父组件</h2>
            <p>父组件接收根组件通过Props传递的参数:
                <span style={{color: '#fff'}}>{msg}</span>
            </p>
        </div>
    )
}

export default Parent;

子组件向父组件通信 函数回调(注意:父子关系是相对参照物,没有绝对一说)

创建父组件

import React, { useState, createContext } from 'react';
import './App.css';

// 引入父组件
import Parent from './page/child'

const App = () => {

  const [childMsg, setChildMsg] = useState('');


  const getChildMsgFn = (childQueryMsg) => setChildMsg(childQueryMsg)

  return (
    <div className="App">
      <div className='gen'>
        <h1>根组件</h1>
        
        <p>接收从子组件传递过来的数据:<span className='setChildMsgStyle'>{childMsg}</span></p>
        
        // 通过传递一个函数到子组件,然后利用这个函数的回调获取子组件传递出来的数据
        <Parent postMsgToParentFn={getChildMsgFn} />
      </div>
    </div>
  );
}

export default App;

创建子组件

import React, {useState, useEffect} from 'react';

const Parent = (props) => {
    
    // 接收从父组件传递进来的函数
    const { postMsgToParentFn} = props;

    return (
        <div className="parent">
            <h2>这是父组件</h2>
			
			// 自定义一个按钮
            <div className='setBtnStyle' onClick={() => postMsgToParentFn('这是子组件传递给父组件的数据!')}>我要向根组件传递一些数据</div>

        </div>
    )
}

export default Parent;

注意:红框出是子组件传递上来的将要展示的数据,箭头标注的地方表示 子组件触发事件
在这里插入图片描述

祖孙(后代)组件间通信,可以使用 createContext, useContext

创建根组件

import React, { useState, createContext } from 'react';
import './App.css';

// 引入父组件
import Parent from './page/parent'

const C = createContext(11111);


const App = () => {

  const msg = '1111'
  const [propsMsg, setPropsMsg] = useState('这是我要传递的参数');
  const [childMsg, setChildMsg] = useState('');

  const getChildMsgFn = (childQueryMsg) => setChildMsg(childQueryMsg)

  return (
    <div className="App">
      <div className='gen'>
        <h1>根组件</h1>
        <p>参数:{msg}</p>
        <p>参数:{propsMsg}</p>
        <p>接收从子组件传递过来的数据:<span className='setChildMsgStyle'>{childMsg}</span></p>

        <C.Provider value={{ msg, msg1: propsMsg }}>
          <Parent msg={propsMsg} postMsgToParentFn={getChildMsgFn} />
        </C.Provider>
      </div>
    </div>
  );
}

export default App;

export {
  C
}

创建父组件

import React, {useState, useEffect} from 'react';

import Child from './child'

const Parent = (props) => {
    
    const { msg, postMsgToParentFn} = props;

    const msgToParent = '这是子组件传递给父组件的数据!'

    return (
        <div className="parent">
            <h2>这是父组件</h2>
            <p>父组件接收根组件通过Props传递的参数:
                <span style={{color: '#fff'}}>{msg}</span>
            </p>

            <div className='setBtnStyle' onClick={() => postMsgToParentFn(msgToParent)}>我要向根组件传递一些数据</div>

            <Child/>
        </div>
    )
}

export default Parent;


创建子组件

import React,{useContext} from "react";

import {C} from '../App'

const Child = () => {

    const {msg,msg1} = useContext(C);

    return (
        <div className="child">
            <h3>这是子组件</h3>
            <p>接收从根组件通过Context 上下文 传递过来的数据:{msg} --- {msg1}</p>
        </div>
    )
}

export default Child;

不相干组件间通信(不仅限于兄弟组件之间的通信) ,可以利用 node 的 api events

创建 utils.js 作为事件总线
EventBus相当于一个全局的仓库,任何组件都可以去这个仓库里获取事件
它的工作原理是发布/订阅方法,通常称为 Pub/Sub 。

import { EventEmitter } from 'events';

const eventBus = new EventEmitter();

export default eventBus;

兄弟组件1

import React,{useContext, useEffect, useState} from "react";


import eventBus from '../utils'

const Child = () => {

    const [myParams, setMyParams] = useState(null);

    useEffect(() => {
        eventBus.on('myParams', (value) => setMyParams(value));
		return () => {
			// 记得不使用此组件的时候要关闭监听,避免再次进入的时候再次创建一个监听事件,如果如此往复多次,就会创建很多监听事件,这是一种灾难
			eventBus.off('myParams')
		}
    }, [])

    return (
        <div className="child">
            <h3>这是兄弟1组件</h3>

            <p>这是我兄弟给我的数据:{myParams}</p>
        </div>
    )
}

export default Child;

兄弟组件2

import React,{useContext} from "react";

import eventBus from '../utils'

const Child1 = () => {


    const toSubChildDataFn = () => {
        eventBus.emit('myParams', '这是要给兄弟的数据!')
    };

    return (
        <div className="child" style={{backgroundColor: 'blue'}}>
            <h3>这是兄弟2组件</h3>
       
            <div className="setBtnStyle" onClick={() => toSubChildDataFn()}>给兄弟组件传递数据</div>
        </div>
    )
}

export default Child1;

在这里插入图片描述
以上就是关于React 常用的几种数据通信方式,如果更好的方式请留言,让作者也学习一下,如果有错误,欢迎指正,谢谢。

如果本篇文章对你有帮助,麻烦请点个赞,谢谢。

最后感谢广大读者朋友的耐心阅读与包容,祝愿大家心想事成,一切随心随性。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 18:55:53  更:2022-06-29 18:59:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 11:16:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码