useContext 详细解析 及与 createContext 搭配使用解决祖孙多层组件之间传参问题

1. createContext

import { createContext } from 'react'

let defaultValue = {}

const context = createContext(defaultValue) 

export default context;

创建一个 Context 对象,当 React 渲染一个订阅了这个 Context 对象的组件,这个组件会从组件树中离自身最近的那个匹配的 Provider 中读取到当前的 context 值。

只有当组件所处的树中没有匹配到 Provider 时,其 defaultValue 才会生效

2. useContext

import { useContext } from 'react'
impor context from '@/xxx/xxx.ts'  // 引入上面创建的 Context 对象
 
const contextParams = useContext<any>(context)

useContext 接收一个 Context 对象(即 React.createContext 的返回值),并返回该 context 的当前值。

  • useContext 可以帮助我们跨越组件层级直接传递变量,实现数据共享。
  • Context 的作用是:对它所包含的组件树提供全局共享数据的一种技术。

3. 使用

可以分为以下三步

1. 在一个单独的 .ts文件中,引入 createContext 方法,并创建 Context 对象、导出

import { createContext } from 'react'

let defaultValue = {}

const context = createContext(defaultValue) 

export default context;

2. 在父/祖组件中使用 Provider 组件包裹需要接收数据的子组件,并通过 value 属性提供要共享的数据

父组件:


import { useContext } from 'react'
impor context from '@/xxx/xxx.ts'  // 引入上面创建的 Context 对象
 
return (
	<context.Provider value={这里放需要传递的数据}> // 比如 value={{isFullScreen: true, toDoFlag: '1'}}
		需要接收数据的子/孙组件	
		这里的子/孙组件中,如果在嵌套子组件,仍然可以获取共享数据
	</context.Provider>
)

3. 在需要获取公共数据的子/孙组件中,使用 useContext方法、Context 对象,得到 value 的值

子/孙组件:


import React, { useContext } from 'react';
import context from '@/xxx/xxx'

const index = () => {
	const contextParams = useContext(context)  // 获取到value,可以在下面进行使用
	return (
		<></>
	)
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值