React 之 组件之间共享值useContext使用(十五)

1. useContext 是 React 中的一个 Hook,它允许你在组件之间共享值,而不必显式地通过组件树逐层传递 props。当你想要在整个应用程序中传递数据时,使用 useContext 可以使代码更加简洁和易于维护
2. 相当于vue的依赖注入模式:Provide / Inject

useContext 需要与 React.createContext() 一起使用。React.createContext() 会返回一个新的 React Context 对象。这个对象有两个属性:Provider 和Consumer。但是,useContext Hook 使得我们可以直接访问 Context 的值,而不需要使用 Consumer。

使用 useContext 的代码栗子:

import React, { createContext, useContext, useState } from 'react';  

父组件:ThemeProvider
// 创建一个新的 Context 对象  
const ThemeContext = createContext();  
  
// ThemeProvider 组件,用于包裹子组件,并提供一个 theme 属性  
function ThemeProvider({ children }) {  
  const [theme, setTheme] = useState('light');  
  
  // 返回一个对象,该对象会被 ThemeContext.Provider 使用  
  // 这样,所有 ThemeProvider 的子组件(包括嵌套组件)都可以访问到 theme 和 setTheme  
  return (  
    <ThemeContext.Provider value={{ theme, setTheme }}>  
      {children}  
    </ThemeContext.Provider>  
  );  
}  
 
子组件:ThemedButton
// 使用 useContext 访问 ThemeContext 的值  
function ThemedButton() {  
  // 使用 useContext Hook 获取 ThemeContext 的值  
  const { theme, setTheme } = useContext(ThemeContext);  
  
  return (  
    <button  
      onClick={() => setTheme(theme === 'light' ? 'dark' : 'light')}  
      style={{ background: theme }}  
    >  
      Toggle Theme  
    </button>  
  );  
}  
  
function App() {  
  return (  
    <ThemeProvider>  
      <ThemedButton />  
    </ThemeProvider>  
  );  
}  
  
export default App;
React是一种用于构建用户界面的JavaScript库,它将应用程序拆分成小而可重用的组件。而Hooks是React 16.8版本新增的特性,它可以让你在不编写 class 的情况下使用 state 以及其他 React 特性。 在React中,数据共享可以通过Context来实现。而封装Hooks组件可以通过自定义Hooks来实现。 下面是一个简单的例子,展示如何封装Hooks组件实现数据共享: ```javascript import React, { createContext, useContext, useState } from 'react'; // 创建一个Context对象 const CounterContext = createContext(); // 自定义Hook,提供计数器状态和操作函数 function useCounter() { const [count, setCount] = useState(0); const increment = () => { setCount(count + 1); }; const decrement = () => { setCount(count - 1); }; return [count, increment, decrement]; } // CounterProvider组件,提供计数器状态和操作函数 function CounterProvider(props) { const counter = useCounter(); return ( <CounterContext.Provider value={counter}> {props.children} </CounterContext.Provider> ); } // Counter组件使用计数器状态和操作函数 function Counter() { const [count, increment, decrement] = useContext(CounterContext); return ( <div> <p>Count: {count}</p> <button onClick={increment}>Increment</button> <button onClick={decrement}>Decrement</button> </div> ); } // 在App组件使用CounterProvider和Counter组件 function App() { return ( <CounterProvider> <Counter /> </CounterProvider> ); } export default App; ``` 上面的例子中,我们首先定义了一个自定义Hook useCounter,用于提供计数器状态和操作函数。然后,我们创建了一个CounterContext对象,并使用CounterProvider组件来提供计数器状态和操作函数。最后,我们使用useContext Hook在Counter组件中获取计数器状态和操作函数,并渲染出来。 相关问题: 1. React中的Context是什么? 2. Hooks是什么?有哪些常用的Hooks? 3. 自定义Hooks有什么好处? 4. 在React中如何实现数据共享
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

**之火

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值