您现在的位置是:网站首页> 编程资料编程资料
详解React hooks组件通信方法_React_
2023-05-24
393人已围观
简介 详解React hooks组件通信方法_React_
一、前言
组件通信是React中的一个重要的知识点,下面列举一下 react hooks中常用的父子、跨组件通信的方法
二、父子组件通信
1)父组件传值给子组件
子组件代码:
//子组件 const Child = ({ param1, param2 }) => { return <>父组件传递的参数:{param1},{param2}> }param1、param2 为子组件接收父组件的传参,父组件代码如下:
父组件代码
//父组件 const Parent = () => { return }运行效果

2)子组件传值给父组件
子传父严格来讲还是父传子,父组件传递给子组件ref,子组件将想要暴露给父组件的值放在上面,然后父组件就可以使用其值:
首先需要导入对应的模块包useImperativeHandle、useRef,forwardRef :
import React, { useRef, useImperativeHandle, useEffect, forwardRef } from 'react';父组件代码
//父组件 const Parent = () => {//父组件 const ref = useRef(); //ref useEffect(() => { console.log(ref) }, []) return ( ) } 子组件代码
//子组件 const Child = forwardRef(({ },ref) => { useImperativeHandle(ref, () => ({ data: '我是子组件' })); return <>我是子组件> }) 运行后控制台输出
{
"current": {
"data": "我是子组件"
}
}
3)跨组件传值(父传孙子组件)
跨组件传值我们页可以使用最开始介绍的父传子的方法,一层层的嵌套传递,例如:
const Parent = () => { return } //子组件 const Child1 = ({ param1, param2 }) => { return } //子子组件 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 } 子组件和子子组件代码
//子组件无需改动 const Child1 = () => { return } //子子组件 const Child2 = () => { //通过useContext获取父组件的值 const { param1, param2 } = useContext(myContext) return <>父组件传递的参数:{param1},{param2}> } 运行效果

到此这篇关于React hooks组件通信的文章就介绍到这了,更多相关React hooks组件内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- vue对插件(iview,elementui,treeselect)样式的局部修改方式_vue.js_
- Vue动态构建混合数据Treeselect选择树及巨树问题的解决_vue.js_
- vue-treeselect显示unknown的问题及解决_vue.js_
- VueTreeselect 参数options的数据转换-参数normalizer解析_vue.js_
- 关于vue-lunar-full-calendar的使用说明_vue.js_
- 小程序实现简单验证码倒计时_javascript技巧_
- 微信小程序转盘抽奖的实现方法_javascript技巧_
- vuex store 缓存存储原理分析_vue.js_
- vue对象添加属性(key:value)、显示和删除属性方式_vue.js_
- JavaScript中关于递归与回溯的实例详解_javascript技巧_
