irpas技术客

React hooks组件通信_曲鸟

未知 2934

一、前言

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

二、父子组件通信 1)父组件传值给子组件

子组件代码:

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

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

父组件代码

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

运行效果


2)子组件传值给父组件

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

首先需要导入对应的模块包useImperativeHandle、useRef,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}</> }

运行效果



1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,会注明原创字样,如未注明都非原创,如有侵权请联系删除!;3.作者投稿可能会经我们编辑修改或补充;4.本站不提供任何储存功能只提供收集或者投稿人的网盘链接。

标签: #React #hooks组件通信