React中组件通信的几种主要方式

 更新时间:2024年10月28日 10:25:46   作者:算是难了  
React知识中一个主要内容便是组件之间的通信,以下列举几种常用的组件通信方式,通过代码示例介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

一、父传子:

1. 传递多个属性

父组件可以通过 props 传递多个属性给子组件。

示例

// 子组件
function Son(props) {
    return (
        <div>
            This is Son, {props.name} - Age: {props.age}
        </div>
    );    
}
 
// 父组件
function App() {
    const name = 'This is App Name';
    const age = 10;
    return (
        <div>
            <Son name={name} age={age} />
        </div>
    );
}

2. 传递函数作为 props

父组件可以将函数作为 props 传递给子组件,子组件可以调用这个函数来与父组件进行交互。

示例

// 子组件
function Son(props) {
    const handleClick = () => {
        props.onButtonClick('Button clicked!');
    };
 
    return (
        <div>
            This is Son. 
            <button onClick={handleClick}>Click Me</button>
        </div>
    );    
}
 
// 父组件
function App() {
    const handleSonClick = (message) => {
        console.log(message);
    };
 
    return (
        <div>
            <Son onButtonClick={handleSonClick} />
        </div>
    );
}

3. 使用默认值

为子组件的 props 设置默认值,使用 defaultProps

示例

// 子组件
function Son(props) {
    return <div>This is Son, {props.name}</div>;    
}
 
Son.defaultProps = {
    name: 'Default Name'
};
 
// 父组件
function App() {
    return (
        <div>
            <Son /> {/* 不传递 name 属性 */}
        </div>
    );
}

4. PropTypes 验证

使用 prop-types 库可以对传递给子组件的 props 进行类型检查。

示例

import PropTypes from 'prop-types';
 
// 子组件
function Son(props) {
    return <div>This is Son, {props.name}</div>;    
}
 
Son.propTypes = {
    name: PropTypes.string.isRequired, // name 是必需的字符串
};
 
// 父组件
function App() {
    return (
        <div>
            <Son name="This is App Name" />
        </div>
    );
}

5. 传递对象和数组

父组件可以传递对象或数组作为 props,子组件可以直接使用。

示例:

子组件向父组件传递数据的主要方式是通过回调函数。父组件将一个函数作为 props 传递给子组件,子组件在需要时调用这个函数,并将数据作为参数传递给父组件。

// 子组件
function Son(props) {
    return (
        <div>
            This is Son, {props.data.name}, Age: {props.data.age}
        </div>
    );    
}
 
// 父组件
function App() {
    const user = { name: 'John', age: 25 };
    return (
        <div>
            <Son data={user} />
        </div>
    );
}

总结:

  • 多属性传递: 父组件可以传递多个属性给子组件。
  • 函数作为 props: 父组件可以将函数传递给子组件,子组件可以调用这个函数与父组件进行交互。
  • 默认值和类型检查: 可以通过 defaultProps 和 PropTypes 来确保 props 的完整性和正确性。
  • 传递对象和数组: 可以将复杂的数据结构(如对象和数组)作为 props 传递。

二、子传父:

子组件向父组件传递数据的主要方式是通过回调函数。父组件将一个函数作为 props 传递给子组件,子组件在需要时调用这个函数,并将数据作为参数传递给父组件。 

1.基本用法示例:

父组件

import React from 'react';
import Son from './Son';
 
function App() {
    const handleMessage = (msg) => {
        console.log("Received from Son:", msg);
    };
 
    return (
        <div>
            <h1>Parent Component</h1>
            <Son onSendMessage={handleMessage} />
        </div>
    );
}
 
export default App;

子组件

import React from 'react';
 
function Son(props) {
    const sendMessage = () => {
        props.onSendMessage("Hello from Son!");
    };
 
    return (
        <div>
            <h2>Child Component</h2>
            <button onClick={sendMessage}>Send Message to Parent</button>
        </div>
    );
}
 
export default Son;

2. 传递事件数据

子组件可以传递事件数据给父组件,通常用于处理用户输入或按钮点击。

示例

// 父组件
function App() {
    const handleInputChange = (inputValue) => {
        console.log("Input from Son:", inputValue);
    };
 
    return (
        <div>
            <h1>Parent Component</h1>
            <Son onInputChange={handleInputChange} />
        </div>
    );
}
 
// 子组件
function Son(props) {
    const handleChange = (event) => {
        props.onInputChange(event.target.value);
    };
 
    return (
        <div>
            <h2>Child Component</h2>
            <input type="text" onChange={handleChange} placeholder="Type something..." />
        </div>
    );
}

3. 传递多个参数

子组件也可以通过回调函数传递多个参数给父组件。

示例

// 父组件
function App() {
    const handleData = (name, age) => {
        console.log("Received from Son:", name, age);
    };
 
    return (
        <div>
            <h1>Parent Component</h1>
            <Son onSendData={handleData} />
        </div>
    );
}
 
// 子组件
function Son(props) {
    const sendData = () => {
        props.onSendData("John", 30);
    };
 
    return (
        <div>
            <h2>Child Component</h2>
            <button onClick={sendData}>Send Data to Parent</button>
        </div>
    );
}

总结:

  • 回调函数: 子组件通过调用父组件传递的回调函数来传递数据。
  • 事件数据传递: 子组件可以通过回调函数向父组件传递事件数据,如用户输入。
  • 多个参数: 子组件可以通过回调函数传递多个参数给父组件。

三、使用Context机制跨层级组件通信:

App组件——A组件——B组件

1.创建上下文对象:在所有组件外部创建一个上下文对象

import React, { createContext } from 'react';
 
// 创建上下文对象
cosnt MsgContext = createContext()

2.顶层组件提供数据:在顶层组件通过Provider组件提供数据 

// App.js
import React, { useState } from 'react';
import MyContext from './MyContext';
import ComponentA from './ComponentA';
 
const App = () => {
    const [data, setValue] = useState("Hello from Context!");
 
    return (
        <MyContext.Provider value={{ data, setData }}>
            <h1>Top Level Component</h1>
            <A />
        </MyContext.Provider>
    );
};
 
export default App;

3.中间组件A组件(可选)

// ComponentA.js
import React from 'react';
import ComponentB from './ComponentB';
 
const ComponentA = () => {
    return (
        <div>
            <h2>Component A</h2>
            <B />
        </div>
    );
};
 
export default ComponentA;

4.底层组件消费数据: 在底层组件中使用 useContext 钩子获取数据。 

// ComponentB.js
import React, { useContext } from 'react';
import MyContext from './MyContext';
 
const ComponentB = () => {
    const { value, setValue } = useContext(MyContext); // 获取上下文
    const changeValue = () => {
        setValue('update from B'); // 更新上下文值
    };
 
    return (
        <div>
            <h3>Component B</h3>
            <p>Data from Context: {data}</p>
            <button onClick={changeValue}>更新值</button>
        </div>
    );
};
 
export default ComponentB;

总结:

  • 创建 Context: 使用 createContext 创建上下文。
  • 提供 Context: 使用 Context.Provider 在顶层组件中提供数据。
  • 使用 Context: 在子组件中使用 useContext 钩子访问上下文。
  • 更新 Context: 子组件通过调用更新函数来修改上下文的值。

以上就是React中组件通信的几种主要方式的详细内容,更多关于React组件通信方式的资料请关注脚本之家其它相关文章!

相关文章

  • React虚拟列表的实现

    React虚拟列表的实现

    在开发过程中,总是遇到很多列表的显示。当上数量级别的列表渲染于浏览器,终会导致浏览器的性能下降,你可以选择其他方式避免,本文就介绍了虚拟列表来解决这个问题
    2021-05-05
  • 使用reactjs优化了进度条页面性能提高70%

    使用reactjs优化了进度条页面性能提高70%

    这篇文章主要介绍了使用reactjs优化了进度条后页面性能提高了70%的操作技巧,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • react context优化四重奏教程示例

    react context优化四重奏教程示例

    这篇文章主要为大家介绍了react context优化四重奏教程示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • react中的ajax封装实例详解

    react中的ajax封装实例详解

    这篇文章主要介绍了react中的ajax封装实例详解的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下
    2017-10-10
  • React路由管理之React Router总结

    React路由管理之React Router总结

    React项目通常都有很多的URL需要管理,最常使用的解决方案就是React Router了,本篇文章主要介绍了React路由管理之React Router总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • React中state属性和生命周期的使用

    React中state属性和生命周期的使用

    这篇文章主要介绍了React中state属性和生命周期的使用说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • React使用高阶组件与Hooks实现权限拦截教程详细分析

    React使用高阶组件与Hooks实现权限拦截教程详细分析

    高阶组件就是接受一个组件作为参数并返回一个新组件(功能增强的组件)的函数。这里需要注意高阶组件是一个函数,并不是组件,这一点一定要注意,本文给大家分享React高阶组件使用小结,一起看看吧
    2023-01-01
  • React 中使用 Redux 的 4 种写法小结

    React 中使用 Redux 的 4 种写法小结

    这篇文章主要介绍了在 React 中使用 Redux 的 4 种写法,Redux 一般来说并不是必须的,只有在项目比较复杂的时候,比如多个分散在不同地方的组件使用同一个状态,本文就React使用 Redux的相关知识给大家介绍的非常详细,需要的朋友参考下吧
    2022-06-06
  • React hooks useState异步问题及解决

    React hooks useState异步问题及解决

    这篇文章主要介绍了React hooks useState异步问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • React useReducer终极使用教程

    React useReducer终极使用教程

    useReducer是在react V16.8推出的钩子函数,从用法层面来说是可以代替useState。相信前期使用过 React 的前端同学,大都会经历从class语法向hooks用法的转变,react的hooks编程给我们带来了丝滑的函数式编程体验
    2022-10-10

最新评论